home *** CD-ROM | disk | FTP | other *** search
/ Computer Select (Limited Edition) / Computer Select.iso / dobbs / v17n04 / handprin.urc / Recognizer / Analyzer.c next >
MacBinary  |  1992-03-11  |  12.1 KB  |  [TEXT/KAHL]

open in: MacOS 8.1     |     Win98     |     DOS

view JSON data     |     view as text

This file was processed as: MacBinary (archive/macBinary).

You can browse this item here: Analyzer.c

ConfidenceProgramDetectionMatch TypeSupport
66% dexvert Compact Compressed (Unix) (archive/compact) ext Supported
10% dexvert MacBinary (archive/macBinary) fallback Supported
1% dexvert Text File (text/txt) fallback Supported
100% file MacBinary II, inited, Wed Mar 11 10:20:46 1992, modified Wed Mar 11 10:20:46 1992, creator Think C, type ASCII, 11874 bytes "Analyzer.c" , at 0x2ee2 348 bytes resource default (weak)
99% file data default
74% TrID Macintosh plain text (MacBinary) default
25% TrID MacBinary 2 default (weak)
100% siegfried fmt/1762 MacBinary (II) default
100% lsar MacBinary default


id metadata
keyvalue
macFileType[TEXT]
macFileCreator[KAHL]



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 00 0a 41 6e 61 6c 79 7a | 65 72 2e 63 00 00 00 00 |..Analyz|er.c....|
|00000010| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000040| 00 54 45 58 54 4b 41 48 | 4c 01 00 00 00 00 00 00 |.TEXTKAH|L.......|
|00000050| 00 00 00 00 00 2e 62 00 | 00 01 5c a5 e3 d5 ce a5 |......b.|..\.....|
|00000060| e3 d5 ce 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000070| 00 00 00 00 00 00 00 00 | 00 00 81 81 d6 8a 00 00 |........|........|
|00000080| 2f 2a 20 41 6c 6c 20 72 | 69 67 68 74 73 20 72 65 |/* All r|ights re|
|00000090| 73 65 72 76 65 64 2e 20 | 43 6f 70 79 72 69 67 68 |served. |Copyrigh|
|000000a0| 74 20 52 6f 6e 20 41 76 | 69 74 7a 75 72 20 2d 20 |t Ron Av|itzur - |
|000000b0| 31 39 39 32 0d 2a 2f 0d | 0d 23 69 6e 63 6c 75 64 |1992.*/.|.#includ|
|000000c0| 65 20 22 52 65 63 6f 67 | 6e 69 7a 65 72 2e 68 22 |e "Recog|nizer.h"|
|000000d0| 0d 0d 23 64 65 66 69 6e | 65 20 41 4e 47 4c 45 5f |..#defin|e ANGLE_|
|000000e0| 54 48 52 45 53 48 4f 4c | 44 09 35 0d 23 64 65 66 |THRESHOL|D.5.#def|
|000000f0| 69 6e 65 20 44 4f 54 5f | 54 48 52 45 53 48 48 4f |ine DOT_|THRESHHO|
|00000100| 4c 44 09 28 57 61 63 6f | 6d 3f 34 30 3a 34 29 0d |LD.(Waco|m?40:4).|
|00000110| 23 64 65 66 69 6e 65 20 | 50 52 45 5f 41 42 53 09 |#define |PRE_ABS.|
|00000120| 20 09 09 28 57 61 63 6f | 6d 3f 34 30 3a 34 29 0d | ..(Waco|m?40:4).|
|00000130| 23 64 65 66 69 6e 65 20 | 50 52 45 5f 52 41 54 49 |#define |PRE_RATI|
|00000140| 4f 5f 58 20 09 09 38 0d | 23 64 65 66 69 6e 65 20 |O_X ..8.|#define |
|00000150| 50 52 45 5f 52 41 54 49 | 4f 5f 59 20 09 09 38 0d |PRE_RATI|O_Y ..8.|
|00000160| 23 64 65 66 69 6e 65 20 | 46 49 52 53 54 5f 52 41 |#define |FIRST_RA|
|00000170| 54 49 4f 5f 58 20 09 34 | 0d 23 64 65 66 69 6e 65 |TIO_X .4|.#define|
|00000180| 20 46 49 52 53 54 5f 52 | 41 54 49 4f 5f 59 20 09 | FIRST_R|ATIO_Y .|
|00000190| 34 0d 23 64 65 66 69 6e | 65 20 4d 55 4c 54 49 5f |4.#defin|e MULTI_|
|000001a0| 54 49 4d 45 5f 4f 55 54 | 20 54 52 41 49 4e 49 4e |TIME_OUT| TRAININ|
|000001b0| 47 5f 54 49 4d 45 5f 4f | 55 54 0d 0d 73 68 6f 72 |G_TIME_O|UT..shor|
|000001c0| 74 20 43 6f 6c 6c 65 63 | 74 53 74 72 6f 6b 65 28 |t Collec|tStroke(|
|000001d0| 77 68 65 72 65 2c 74 68 | 65 53 74 72 6f 6b 65 29 |where,th|eStroke)|
|000001e0| 0d 20 50 6f 69 6e 74 09 | 77 68 65 72 65 3b 0d 20 |. Point.|where;. |
|000001f0| 53 74 72 6f 6b 65 50 74 | 72 20 74 68 65 53 74 72 |StrokePt|r theStr|
|00000200| 6f 6b 65 3b 0d 20 09 7b | 0d 20 09 6c 6f 6e 67 20 |oke;. .{|. .long |
|00000210| 64 6f 77 6e 5f 74 69 6d | 65 3b 0d 20 09 6c 6f 6e |down_tim|e;. .lon|
|00000220| 67 20 58 6d 69 6e 2c 58 | 6d 61 78 2c 59 6d 69 6e |g Xmin,X|max,Ymin|
|00000230| 2c 59 6d 61 78 3b 0d 09 | 73 68 6f 72 74 20 73 74 |,Ymax;..|short st|
|00000240| 69 6c 6c 5f 64 6f 77 6e | 20 3d 20 54 52 55 45 2c |ill_down| = TRUE,|
|00000250| 69 20 3d 20 30 2c 20 72 | 65 73 75 6c 74 20 3d 20 |i = 0, r|esult = |
|00000260| 30 3b 0d 09 50 6f 69 6e | 74 20 6c 61 73 74 2c 64 |0;..Poin|t last,d|
|00000270| 72 61 77 6d 65 3b 0d 09 | 50 65 6e 53 74 61 74 65 |rawme;..|PenState|
|00000280| 20 74 68 65 50 6e 53 74 | 61 74 65 3b 0d 20 09 47 | thePnSt|ate;. .G|
|00000290| 65 74 50 65 6e 53 74 61 | 74 65 20 28 20 26 74 68 |etPenSta|te ( &th|
|000002a0| 65 50 6e 53 74 61 74 65 | 20 29 3b 0d 0d 09 69 66 |ePnState| );...if|
|000002b0| 20 28 57 61 63 6f 6d 29 | 20 7b 0d 09 09 64 72 61 | (Wacom)| {...dra|
|000002c0| 77 6d 65 2e 68 20 3d 20 | 54 41 42 5f 54 4f 5f 53 |wme.h = |TAB_TO_S|
|000002d0| 43 52 45 45 4e 5f 58 28 | 77 68 65 72 65 2e 68 29 |CREEN_X(|where.h)|
|000002e0| 3b 0d 09 09 64 72 61 77 | 6d 65 2e 76 20 3d 20 54 |;...draw|me.v = T|
|000002f0| 41 42 5f 54 4f 5f 53 43 | 52 45 45 4e 5f 59 28 77 |AB_TO_SC|REEN_Y(w|
|00000300| 68 65 72 65 2e 76 29 3b | 0d 09 09 47 6c 6f 62 61 |here.v);|...Globa|
|00000310| 6c 54 6f 4c 6f 63 61 6c | 28 26 64 72 61 77 6d 65 |lToLocal|(&drawme|
|00000320| 29 3b 0d 09 09 7d 0d 09 | 65 6c 73 65 0d 09 09 64 |);...}..|else...d|
|00000330| 72 61 77 6d 65 20 3d 20 | 77 68 65 72 65 3b 0d 09 |rawme = |where;..|
|00000340| 50 65 6e 4d 6f 64 65 28 | 70 61 74 58 6f 72 29 3b |PenMode(|patXor);|
|00000350| 0d 09 50 65 6e 53 69 7a | 65 28 31 2c 31 29 3b 0d |..PenSiz|e(1,1);.|
|00000360| 09 4d 6f 76 65 54 6f 28 | 64 72 61 77 6d 65 2e 68 |.MoveTo(|drawme.h|
|00000370| 2c 64 72 61 77 6d 65 2e | 76 29 3b 0d 09 4c 69 6e |,drawme.|v);..Lin|
|00000380| 65 54 6f 28 64 72 61 77 | 6d 65 2e 68 2c 64 72 61 |eTo(draw|me.h,dra|
|00000390| 77 6d 65 2e 76 29 3b 0d | 0d 09 6c 61 73 74 20 3d |wme.v);.|..last =|
|000003a0| 20 77 68 65 72 65 3b 0d | 09 58 6d 69 6e 20 3d 20 | where;.|.Xmin = |
|000003b0| 58 6d 61 78 20 3d 20 77 | 68 65 72 65 2e 68 3b 0d |Xmax = w|here.h;.|
|000003c0| 09 59 6d 69 6e 20 3d 20 | 59 6d 61 78 20 3d 20 77 |.Ymin = |Ymax = w|
|000003d0| 68 65 72 65 2e 76 3b 0d | 09 74 68 65 53 74 72 6f |here.v;.|.theStro|
|000003e0| 6b 65 2d 3e 49 6e 6b 5b | 69 2b 2b 5d 20 3d 20 77 |ke->Ink[|i++] = w|
|000003f0| 68 65 72 65 3b 0d 0d 09 | 64 6f 77 6e 5f 74 69 6d |here;...|down_tim|
|00000400| 65 20 3d 20 54 69 63 6b | 43 6f 75 6e 74 28 29 3b |e = Tick|Count();|
|00000410| 0d 09 77 68 69 6c 65 20 | 28 73 74 69 6c 6c 5f 64 |..while |(still_d|
|00000420| 6f 77 6e 20 26 26 20 69 | 20 3c 20 4d 41 58 5f 50 |own && i| < MAX_P|
|00000430| 4f 49 4e 54 53 29 20 7b | 0d 0d 09 09 69 66 20 28 |OINTS) {|....if (|
|00000440| 50 61 75 73 65 49 73 4d | 6f 75 73 65 29 20 7b 0d |PauseIsM|ouse) {.|
|00000450| 09 09 09 69 66 20 28 21 | 54 72 61 69 6e 69 6e 67 |...if (!|Training|
|00000460| 20 26 26 20 54 69 63 6b | 43 6f 75 6e 74 28 29 20 | && Tick|Count() |
|00000470| 2d 20 64 6f 77 6e 5f 74 | 69 6d 65 20 3e 20 4d 55 |- down_t|ime > MU|
|00000480| 4c 54 49 5f 54 49 4d 45 | 5f 4f 55 54 20 26 26 0d |LTI_TIME|_OUT &&.|
|00000490| 09 09 09 09 58 6d 61 78 | 20 2d 20 58 6d 69 6e 20 |....Xmax| - Xmin |
|000004a0| 3c 20 44 4f 54 5f 54 48 | 52 45 53 48 48 4f 4c 44 |< DOT_TH|RESHHOLD|
|000004b0| 20 26 26 0d 09 09 09 09 | 59 6d 61 78 20 2d 20 59 | &&.....|Ymax - Y|
|000004c0| 6d 69 6e 20 3c 20 44 4f | 54 5f 54 48 52 45 53 48 |min < DO|T_THRESH|
|000004d0| 48 4f 4c 44 29 0d 09 09 | 09 7b 0d 09 09 09 73 68 |HOLD)...|.{....sh|
|000004e0| 6f 72 74 20 6a 3b 0d 09 | 09 09 66 6f 72 20 28 6a |ort j;..|..for (j|
|000004f0| 20 3d 20 30 3b 20 6a 20 | 3c 20 69 3b 20 6a 2b 2b | = 0; j |< i; j++|
|00000500| 29 20 7b 0d 09 09 09 09 | 77 68 65 72 65 20 3d 20 |) {.....|where = |
|00000510| 74 68 65 53 74 72 6f 6b | 65 2d 3e 49 6e 6b 5b 6a |theStrok|e->Ink[j|
|00000520| 5d 3b 0d 09 09 09 09 69 | 66 20 28 57 61 63 6f 6d |];.....i|f (Wacom|
|00000530| 29 20 7b 0d 09 09 09 09 | 09 64 72 61 77 6d 65 2e |) {.....|.drawme.|
|00000540| 68 20 3d 20 54 41 42 5f | 54 4f 5f 53 43 52 45 45 |h = TAB_|TO_SCREE|
|00000550| 4e 5f 58 28 77 68 65 72 | 65 2e 68 29 3b 0d 09 09 |N_X(wher|e.h);...|
|00000560| 09 09 09 64 72 61 77 6d | 65 2e 76 20 3d 20 54 41 |...drawm|e.v = TA|
|00000570| 42 5f 54 4f 5f 53 43 52 | 45 45 4e 5f 59 28 77 68 |B_TO_SCR|EEN_Y(wh|
|00000580| 65 72 65 2e 76 29 3b 0d | 09 09 09 09 09 47 6c 6f |ere.v);.|.....Glo|
|00000590| 62 61 6c 54 6f 4c 6f 63 | 61 6c 28 26 64 72 61 77 |balToLoc|al(&draw|
|000005a0| 6d 65 29 3b 0d 09 09 09 | 09 09 7d 0d 09 09 09 09 |me);....|..}.....|
|000005b0| 65 6c 73 65 0d 09 09 09 | 09 09 64 72 61 77 6d 65 |else....|..drawme|
|000005c0| 20 3d 20 77 68 65 72 65 | 3b 0d 0d 09 09 09 09 4d | = where|;......M|
|000005d0| 6f 76 65 54 6f 28 64 72 | 61 77 6d 65 2e 68 2c 64 |oveTo(dr|awme.h,d|
|000005e0| 72 61 77 6d 65 2e 76 29 | 3b 0d 09 09 09 09 4c 69 |rawme.v)|;.....Li|
|000005f0| 6e 65 54 6f 28 64 72 61 | 77 6d 65 2e 68 2c 64 72 |neTo(dra|wme.h,dr|
|00000600| 61 77 6d 65 2e 76 29 3b | 0d 09 09 09 09 7d 0d 09 |awme.v);|.....}..|
|00000610| 09 09 72 65 73 75 6c 74 | 20 3d 20 31 3b 0d 09 09 |..result| = 1;...|
|00000620| 09 67 6f 74 6f 20 44 4f | 4e 45 3b 0d 09 09 09 7d |.goto DO|NE;....}|
|00000630| 0d 09 09 7d 0d 0d 09 09 | 69 66 20 28 57 61 63 6f |...}....|if (Waco|
|00000640| 6d 29 20 7b 0d 09 09 09 | 69 66 20 28 54 52 65 63 |m) {....|if (TRec|
|00000650| 6f 72 64 2d 3e 75 70 64 | 61 74 65 46 6c 61 67 73 |ord->upd|ateFlags|
|00000660| 20 26 20 46 52 45 53 48 | 44 41 54 41 29 0d 09 09 | & FRESH|DATA)...|
|00000670| 09 09 09 54 52 65 63 6f | 72 64 2d 3e 75 70 64 61 |...TReco|rd->upda|
|00000680| 74 65 46 6c 61 67 73 20 | 26 3d 20 7e 46 52 45 53 |teFlags |&= ~FRES|
|00000690| 48 44 41 54 41 3b 0d 09 | 09 09 65 6c 73 65 09 63 |HDATA;..|..else.c|
|000006a0| 6f 6e 74 69 6e 75 65 3b | 0d 09 09 09 77 68 65 72 |ontinue;|....wher|
|000006b0| 65 2e 68 20 3d 20 54 52 | 65 63 6f 72 64 2d 3e 78 |e.h = TR|ecord->x|
|000006c0| 43 6f 6f 72 64 3b 0d 09 | 09 09 77 68 65 72 65 2e |Coord;..|..where.|
|000006d0| 76 20 3d 20 54 52 65 63 | 6f 72 64 2d 3e 79 43 6f |v = TRec|ord->yCo|
|000006e0| 6f 72 64 3b 0d 09 09 09 | 64 72 61 77 6d 65 2e 68 |ord;....|drawme.h|
|000006f0| 20 3d 20 54 41 42 5f 54 | 4f 5f 53 43 52 45 45 4e | = TAB_T|O_SCREEN|
|00000700| 5f 58 28 54 52 65 63 6f | 72 64 2d 3e 78 43 6f 6f |_X(TReco|rd->xCoo|
|00000710| 72 64 29 3b 0d 09 09 09 | 64 72 61 77 6d 65 2e 76 |rd);....|drawme.v|
|00000720| 20 3d 20 54 41 42 5f 54 | 4f 5f 53 43 52 45 45 4e | = TAB_T|O_SCREEN|
|00000730| 5f 59 28 54 52 65 63 6f | 72 64 2d 3e 79 43 6f 6f |_Y(TReco|rd->yCoo|
|00000740| 72 64 29 3b 0d 09 09 09 | 47 6c 6f 62 61 6c 54 6f |rd);....|GlobalTo|
|00000750| 4c 6f 63 61 6c 28 26 64 | 72 61 77 6d 65 29 3b 0d |Local(&d|rawme);.|
|00000760| 09 09 09 73 74 69 6c 6c | 5f 64 6f 77 6e 20 3d 20 |...still|_down = |
|00000770| 54 52 65 63 6f 72 64 2d | 3e 62 75 74 74 6f 6e 73 |TRecord-|>buttons|
|00000780| 3b 0d 09 09 09 7d 0d 09 | 09 65 6c 73 65 20 7b 0d |;....}..|.else {.|
|00000790| 09 09 09 47 65 74 4d 6f | 75 73 65 28 26 77 68 65 |...GetMo|use(&whe|
|000007a0| 72 65 29 3b 0d 09 09 09 | 64 72 61 77 6d 65 20 3d |re);....|drawme =|
|000007b0| 20 77 68 65 72 65 3b 0d | 09 09 09 73 74 69 6c 6c | where;.|...still|
|000007c0| 5f 64 6f 77 6e 20 3d 20 | 28 53 74 69 6c 6c 44 6f |_down = |(StillDo|
|000007d0| 77 6e 28 29 20 7c 7c 20 | 53 74 69 6c 6c 44 6f 77 |wn() || |StillDow|
|000007e0| 6e 28 29 7c 7c 20 53 74 | 69 6c 6c 44 6f 77 6e 28 |n()|| St|illDown(|
|000007f0| 29 20 7c 7c 20 53 74 69 | 6c 6c 44 6f 77 6e 28 29 |) || Sti|llDown()|
|00000800| 29 3b 0d 09 09 09 7d 0d | 09 09 69 66 20 28 77 68 |);....}.|..if (wh|
|00000810| 65 72 65 2e 68 20 3d 3d | 20 6c 61 73 74 2e 68 20 |ere.h ==| last.h |
|00000820| 26 26 20 77 68 65 72 65 | 2e 76 20 3d 3d 20 6c 61 |&& where|.v == la|
|00000830| 73 74 2e 76 29 20 63 6f | 6e 74 69 6e 75 65 3b 0d |st.v) co|ntinue;.|
|00000840| 09 09 69 66 20 28 77 68 | 65 72 65 2e 68 20 3e 20 |..if (wh|ere.h > |
|00000850| 58 6d 61 78 29 20 58 6d | 61 78 20 3d 20 77 68 65 |Xmax) Xm|ax = whe|
|00000860| 72 65 2e 68 3b 0d 09 09 | 69 66 20 28 77 68 65 72 |re.h;...|if (wher|
|00000870| 65 2e 68 20 3c 20 58 6d | 69 6e 29 20 58 6d 69 6e |e.h < Xm|in) Xmin|
|00000880| 20 3d 20 77 68 65 72 65 | 2e 68 3b 0d 09 09 69 66 | = where|.h;...if|
|00000890| 20 28 77 68 65 72 65 2e | 76 20 3e 20 59 6d 61 78 | (where.|v > Ymax|
|000008a0| 29 20 59 6d 61 78 20 3d | 20 77 68 65 72 65 2e 76 |) Ymax =| where.v|
|000008b0| 3b 0d 09 09 69 66 20 28 | 77 68 65 72 65 2e 76 20 |;...if (|where.v |
|000008c0| 3c 20 59 6d 69 6e 29 20 | 59 6d 69 6e 20 3d 20 77 |< Ymin) |Ymin = w|
|000008d0| 68 65 72 65 2e 76 3b 0d | 09 09 74 68 65 53 74 72 |here.v;.|..theStr|
|000008e0| 6f 6b 65 2d 3e 49 6e 6b | 5b 69 2b 2b 5d 20 3d 20 |oke->Ink|[i++] = |
|000008f0| 6c 61 73 74 20 3d 20 77 | 68 65 72 65 3b 0d 09 09 |last = w|here;...|
|00000900| 4d 6f 76 65 54 6f 28 64 | 72 61 77 6d 65 2e 68 2c |MoveTo(d|rawme.h,|
|00000910| 64 72 61 77 6d 65 2e 76 | 29 3b 20 4c 69 6e 65 54 |drawme.v|); LineT|
|00000920| 6f 28 64 72 61 77 6d 65 | 2e 68 2c 64 72 61 77 6d |o(drawme|.h,drawm|
|00000930| 65 2e 76 29 3b 0d 09 09 | 7d 0d 09 50 65 6e 4e 6f |e.v);...|}..PenNo|
|00000940| 72 6d 61 6c 28 29 3b 0d | 09 74 68 65 53 74 72 6f |rmal();.|.theStro|
|00000950| 6b 65 2d 3e 49 6e 6b 5f | 4e 75 6d 20 3d 20 69 3b |ke->Ink_|Num = i;|
|00000960| 0d 09 74 68 65 53 74 72 | 6f 6b 65 2d 3e 65 6e 64 |..theStr|oke->end|
|00000970| 5f 74 69 6d 65 09 09 3d | 20 54 69 63 6b 43 6f 75 |_time..=| TickCou|
|00000980| 6e 74 28 29 3b 0d 09 74 | 68 65 53 74 72 6f 6b 65 |nt();..t|heStroke|
|00000990| 2d 3e 48 65 69 67 68 74 | 09 09 09 3d 20 59 6d 61 |->Height|...= Yma|
|000009a0| 78 20 2d 20 59 6d 69 6e | 20 2b 20 31 3b 0d 09 74 |x - Ymin| + 1;..t|
|000009b0| 68 65 53 74 72 6f 6b 65 | 2d 3e 57 69 64 74 68 09 |heStroke|->Width.|
|000009c0| 09 09 3d 20 58 6d 61 78 | 20 2d 20 58 6d 69 6e 20 |..= Xmax| - Xmin |
|000009d0| 2b 20 31 3b 0d 09 74 68 | 65 53 74 72 6f 6b 65 2d |+ 1;..th|eStroke-|
|000009e0| 3e 58 6d 69 6e 09 09 09 | 3d 20 58 6d 69 6e 3b 0d |>Xmin...|= Xmin;.|
|000009f0| 09 74 68 65 53 74 72 6f | 6b 65 2d 3e 58 6d 61 78 |.theStro|ke->Xmax|
|00000a00| 09 09 09 3d 20 58 6d 61 | 78 3b 0d 09 74 68 65 53 |...= Xma|x;..theS|
|00000a10| 74 72 6f 6b 65 2d 3e 59 | 6d 69 6e 09 09 09 3d 20 |troke->Y|min...= |
|00000a20| 59 6d 69 6e 3b 0d 09 74 | 68 65 53 74 72 6f 6b 65 |Ymin;..t|heStroke|
|00000a30| 2d 3e 59 6d 61 78 09 09 | 09 3d 20 59 6d 61 78 3b |->Ymax..|.= Ymax;|
|00000a40| 0d 09 74 68 65 53 74 72 | 6f 6b 65 2d 3e 41 73 70 |..theStr|oke->Asp|
|00000a50| 65 63 74 5f 52 61 74 69 | 6f 09 3d 20 28 28 64 6f |ect_Rati|o.= ((do|
|00000a60| 75 62 6c 65 29 74 68 65 | 53 74 72 6f 6b 65 2d 3e |uble)the|Stroke->|
|00000a70| 48 65 69 67 68 74 20 2d | 20 74 68 65 53 74 72 6f |Height -| theStro|
|00000a80| 6b 65 2d 3e 57 69 64 74 | 68 29 20 2f 0d 09 09 09 |ke->Widt|h) /....|
|00000a90| 09 09 09 09 09 09 09 09 | 09 09 28 74 68 65 53 74 |........|..(theSt|
|00000aa0| 72 6f 6b 65 2d 3e 48 65 | 69 67 68 74 20 2b 20 74 |roke->He|ight + t|
|00000ab0| 68 65 53 74 72 6f 6b 65 | 2d 3e 57 69 64 74 68 29 |heStroke|->Width)|
|00000ac0| 3b 0d 09 74 68 65 53 74 | 72 6f 6b 65 2d 3e 41 73 |;..theSt|roke->As|
|00000ad0| 70 65 63 74 5f 52 61 74 | 69 6f 09 3d 20 28 64 6f |pect_Rat|io.= (do|
|00000ae0| 75 62 6c 65 29 74 68 65 | 53 74 72 6f 6b 65 2d 3e |uble)the|Stroke->|
|00000af0| 48 65 69 67 68 74 20 2f | 20 74 68 65 53 74 72 6f |Height /| theStro|
|00000b00| 6b 65 2d 3e 57 69 64 74 | 68 3b 0d 09 53 69 6d 70 |ke->Widt|h;..Simp|
|00000b10| 6c 69 66 79 28 74 68 65 | 53 74 72 6f 6b 65 2c 74 |lify(the|Stroke,t|
|00000b20| 68 65 53 74 72 6f 6b 65 | 2d 3e 49 6e 6b 2c 74 68 |heStroke|->Ink,th|
|00000b30| 65 53 74 72 6f 6b 65 2d | 3e 49 6e 6b 5f 4e 75 6d |eStroke-|>Ink_Num|
|00000b40| 29 3b 0d 09 41 6e 61 6c | 79 7a 65 28 74 68 65 53 |);..Anal|yze(theS|
|00000b50| 74 72 6f 6b 65 29 3b 0d | 09 72 65 73 75 6c 74 20 |troke);.|.result |
|00000b60| 3d 20 30 3b 0d 0d 44 4f | 4e 45 3a 0d 09 53 65 74 |= 0;..DO|NE:..Set|
|00000b70| 50 65 6e 53 74 61 74 65 | 20 28 20 26 74 68 65 50 |PenState| ( &theP|
|00000b80| 6e 53 74 61 74 65 20 29 | 3b 0d 09 72 65 74 75 72 |nState )|;..retur|
|00000b90| 6e 20 72 65 73 75 6c 74 | 3b 0d 09 7d 0d 0d 73 68 |n result|;..}..sh|
|00000ba0| 6f 72 74 20 50 72 6f 63 | 65 73 73 33 28 72 65 67 |ort Proc|ess3(reg|
|00000bb0| 69 73 74 65 72 20 50 6f | 69 6e 74 20 2a 50 2c 72 |ister Po|int *P,r|
|00000bc0| 65 67 69 73 74 65 72 20 | 50 6f 69 6e 74 20 2a 51 |egister |Point *Q|
|00000bd0| 2c 73 68 6f 72 74 20 6e | 75 6d 2c 73 68 6f 72 74 |,short n|um,short|
|00000be0| 2c 73 68 6f 72 74 2c 73 | 68 6f 72 74 2c 73 68 6f |,short,s|hort,sho|
|00000bf0| 72 74 29 3b 0d 73 68 6f | 72 74 20 50 72 6f 63 65 |rt);.sho|rt Proce|
|00000c00| 73 73 33 28 72 65 67 69 | 73 74 65 72 20 50 6f 69 |ss3(regi|ster Poi|
|00000c10| 6e 74 20 2a 50 2c 72 65 | 67 69 73 74 65 72 20 50 |nt *P,re|gister P|
|00000c20| 6f 69 6e 74 20 2a 51 2c | 73 68 6f 72 74 20 6e 75 |oint *Q,|short nu|
|00000c30| 6d 2c 73 68 6f 72 74 20 | 78 64 2c 73 68 6f 72 74 |m,short |xd,short|
|00000c40| 20 79 64 2c 73 68 6f 72 | 74 20 78 64 32 2c 73 68 | yd,shor|t xd2,sh|
|00000c50| 6f 72 74 20 79 64 32 29 | 0d 09 7b 0d 09 72 65 67 |ort yd2)|..{..reg|
|00000c60| 69 73 74 65 72 20 73 68 | 6f 72 74 20 69 2c 6e 3b |ister sh|ort i,n;|
|00000c70| 0d 09 72 65 67 69 73 74 | 65 72 20 73 68 6f 72 74 |..regist|er short|
|00000c80| 20 64 78 2c 64 79 3b 0d | 09 0d 09 6e 20 3d 20 30 | dx,dy;.|...n = 0|
|00000c90| 3b 0d 09 50 5b 30 5d 20 | 3d 20 51 5b 30 5d 3b 0d |;..P[0] |= Q[0];.|
|00000ca0| 09 66 6f 72 20 28 69 20 | 3d 20 31 3b 20 69 20 3c |.for (i |= 1; i <|
|00000cb0| 20 6e 75 6d 20 2d 20 31 | 3b 20 69 2b 2b 29 20 7b | num - 1|; i++) {|
|00000cc0| 0d 09 09 64 78 20 3d 20 | 51 5b 69 5d 2e 68 20 2d |...dx = |Q[i].h -|
|00000cd0| 20 50 5b 6e 5d 2e 68 3b | 20 64 78 20 3d 20 41 42 | P[n].h;| dx = AB|
|00000ce0| 53 28 64 78 29 3b 0d 09 | 09 64 79 20 3d 20 51 5b |S(dx);..|.dy = Q[|
|00000cf0| 69 5d 2e 76 20 2d 20 50 | 5b 6e 5d 2e 76 3b 20 64 |i].v - P|[n].v; d|
|00000d00| 79 20 3d 20 41 42 53 28 | 64 79 29 3b 0d 09 09 69 |y = ABS(|dy);...i|
|00000d10| 66 20 28 64 78 20 2b 20 | 64 79 20 3c 20 50 52 45 |f (dx + |dy < PRE|
|00000d20| 5f 41 42 53 29 09 63 6f | 6e 74 69 6e 75 65 3b 0d |_ABS).co|ntinue;.|
|00000d30| 09 09 69 66 20 28 64 78 | 20 3c 20 78 64 20 26 26 |..if (dx| < xd &&|
|00000d40| 20 64 79 20 3c 20 79 64 | 29 09 63 6f 6e 74 69 6e | dy < yd|).contin|
|00000d50| 75 65 3b 0d 09 09 69 66 | 20 28 6e 20 3d 3d 20 30 |ue;...if| (n == 0|
|00000d60| 20 26 26 20 64 78 20 3c | 20 78 64 32 20 26 26 20 | && dx <| xd2 && |
|00000d70| 64 79 20 3c 20 79 64 32 | 29 20 63 6f 6e 74 69 6e |dy < yd2|) contin|
|00000d80| 75 65 3b 0d 09 09 6e 2b | 2b 3b 0d 09 09 50 5b 6e |ue;...n+|+;...P[n|
|00000d90| 5d 20 3d 20 51 5b 69 5d | 3b 0d 09 09 7d 0d 09 64 |] = Q[i]|;...}..d|
|00000da0| 78 20 3d 20 51 5b 6e 75 | 6d 20 2d 20 31 5d 2e 68 |x = Q[nu|m - 1].h|
|00000db0| 20 2d 20 50 5b 6e 5d 2e | 68 3b 0d 09 64 79 20 3d | - P[n].|h;..dy =|
|00000dc0| 20 51 5b 6e 75 6d 20 2d | 20 31 5d 2e 76 20 2d 20 | Q[num -| 1].v - |
|00000dd0| 50 5b 6e 5d 2e 76 3b 0d | 09 69 66 20 28 41 42 53 |P[n].v;.|.if (ABS|
|00000de0| 28 64 78 29 20 2b 20 41 | 42 53 28 64 79 29 20 3e |(dx) + A|BS(dy) >|
|00000df0| 20 50 52 45 5f 41 42 53 | 29 0d 09 09 6e 2b 2b 3b | PRE_ABS|)...n++;|
|00000e00| 0d 09 50 5b 6e 5d 20 3d | 20 51 5b 6e 75 6d 20 2d |..P[n] =| Q[num -|
|00000e10| 20 31 5d 3b 0d 09 72 65 | 74 75 72 6e 20 6e 20 2b | 1];..re|turn n +|
|00000e20| 20 31 3b 0d 09 7d 0d 0d | 73 68 6f 72 74 20 44 74 | 1;..}..|short Dt|
|00000e30| 28 73 68 6f 72 74 20 74 | 31 2c 73 68 6f 72 74 20 |(short t|1,short |
|00000e40| 74 32 29 3b 0d 73 68 6f | 72 74 20 44 74 28 73 68 |t2);.sho|rt Dt(sh|
|00000e50| 6f 72 74 20 74 31 2c 73 | 68 6f 72 74 20 74 32 29 |ort t1,s|hort t2)|
|00000e60| 0d 09 7b 0d 09 73 68 6f | 72 74 20 64 74 2c 61 3b |..{..sho|rt dt,a;|
|00000e70| 0d 09 64 74 20 3d 20 74 | 32 20 2d 20 74 31 3b 0d |..dt = t|2 - t1;.|
|00000e80| 09 61 20 3d 20 41 42 53 | 28 64 74 29 3b 0d 09 69 |.a = ABS|(dt);..i|
|00000e90| 66 09 09 09 28 61 20 3d | 3d 20 31 38 30 29 20 64 |f...(a =|= 180) d|
|00000ea0| 74 20 3d 20 31 38 30 3b | 0d 09 65 6c 73 65 20 69 |t = 180;|..else i|
|00000eb0| 66 09 28 61 20 3e 20 20 | 31 38 30 29 20 7b 0d 09 |f.(a > |180) {..|
|00000ec0| 09 69 66 09 09 09 28 74 | 32 3e 30 29 20 64 74 20 |.if...(t|2>0) dt |
|00000ed0| 2d 3d 20 33 36 30 3b 0d | 09 09 65 6c 73 65 20 69 |-= 360;.|..else i|
|00000ee0| 66 20 09 28 74 31 3e 30 | 29 20 64 74 20 2b 3d 20 |f .(t1>0|) dt += |
|00000ef0| 33 36 30 3b 0d 09 09 7d | 0d 09 72 65 74 75 72 6e |360;...}|..return|
|00000f00| 20 64 74 3b 0d 09 7d 0d | 0d 73 68 6f 72 74 20 50 | dt;..}.|.short P|
|00000f10| 72 6f 63 65 73 73 34 28 | 50 6f 69 6e 74 20 2a 50 |rocess4(|Point *P|
|00000f20| 2c 50 6f 69 6e 74 20 2a | 51 2c 73 68 6f 72 74 20 |,Point *|Q,short |
|00000f30| 4e 29 3b 0d 73 68 6f 72 | 74 20 50 72 6f 63 65 73 |N);.shor|t Proces|
|00000f40| 73 34 28 50 6f 69 6e 74 | 20 2a 50 2c 50 6f 69 6e |s4(Point| *P,Poin|
|00000f50| 74 20 2a 51 2c 73 68 6f | 72 74 20 4e 29 0d 09 7b |t *Q,sho|rt N)..{|
|00000f60| 0d 09 50 6f 69 6e 74 20 | 41 2c 42 2c 43 3b 0d 09 |..Point |A,B,C;..|
|00000f70| 73 68 6f 72 74 20 64 74 | 2c 74 31 2c 69 2c 6e 20 |short dt|,t1,i,n |
|00000f80| 3d 20 31 3b 0d 09 0d 09 | 41 20 3d 20 50 5b 30 5d |= 1;....|A = P[0]|
|00000f90| 20 3d 20 51 5b 30 5d 3b | 0d 09 42 20 3d 20 50 5b | = Q[0];|..B = P[|
|00000fa0| 31 5d 20 3d 20 51 5b 31 | 5d 3b 0d 09 74 31 20 3d |1] = Q[1|];..t1 =|
|00000fb0| 20 41 54 41 4e 32 28 42 | 2e 76 20 2d 20 41 2e 76 | ATAN2(B|.v - A.v|
|00000fc0| 2c 42 2e 68 20 2d 20 41 | 2e 68 29 3b 0d 09 66 6f |,B.h - A|.h);..fo|
|00000fd0| 72 20 28 69 20 3d 20 32 | 3b 20 69 20 3c 20 4e 3b |r (i = 2|; i < N;|
|00000fe0| 20 69 2b 2b 29 20 7b 0d | 09 09 43 20 3d 20 51 5b | i++) {.|..C = Q[|
|00000ff0| 69 5d 3b 0d 09 09 64 74 | 20 3d 20 44 74 28 74 31 |i];...dt| = Dt(t1|
|00001000| 2c 41 54 41 4e 32 28 43 | 2e 76 20 2d 20 42 2e 76 |,ATAN2(C|.v - B.v|
|00001010| 2c 43 2e 68 20 2d 20 42 | 2e 68 29 29 3b 0d 09 09 |,C.h - B|.h));...|
|00001020| 69 66 20 28 41 42 53 28 | 64 74 29 20 3c 20 41 4e |if (ABS(|dt) < AN|
|00001030| 47 4c 45 5f 54 48 52 45 | 53 48 4f 4c 44 29 0d 09 |GLE_THRE|SHOLD)..|
|00001040| 09 09 50 5b 6e 5d 20 3d | 20 42 20 3d 20 43 3b 0d |..P[n] =| B = C;.|
|00001050| 09 09 65 6c 73 65 20 7b | 0d 09 09 09 41 20 3d 20 |..else {|....A = |
|00001060| 42 3b 0d 09 09 09 42 20 | 3d 20 43 3b 0d 09 09 09 |B;....B |= C;....|
|00001070| 74 31 20 3d 20 41 54 41 | 4e 32 28 42 2e 76 20 2d |t1 = ATA|N2(B.v -|
|00001080| 20 41 2e 76 2c 42 2e 68 | 20 2d 20 41 2e 68 29 3b | A.v,B.h| - A.h);|
|00001090| 0d 09 09 09 6e 2b 2b 3b | 0d 09 09 09 50 5b 6e 5d |....n++;|....P[n]|
|000010a0| 20 3d 20 43 3b 0d 09 09 | 09 7d 0d 09 09 7d 0d 09 | = C;...|.}...}..|
|000010b0| 72 65 74 75 72 6e 20 6e | 20 2b 20 31 3b 0d 09 7d |return n| + 1;..}|
|000010c0| 0d 0d 76 6f 69 64 09 53 | 69 6d 70 6c 69 66 79 28 |..void.S|implify(|
|000010d0| 53 74 72 6f 6b 65 50 74 | 72 20 74 68 65 53 74 72 |StrokePt|r theStr|
|000010e0| 6f 6b 65 2c 50 6f 69 6e | 74 20 2a 49 6e 6b 2c 73 |oke,Poin|t *Ink,s|
|000010f0| 68 6f 72 74 20 4e 29 0d | 09 7b 0d 09 50 6f 69 6e |hort N).|.{..Poin|
|00001100| 74 20 51 5b 4d 41 58 5f | 50 4f 49 4e 54 53 5d 3b |t Q[MAX_|POINTS];|
|00001110| 0d 09 73 68 6f 72 74 20 | 77 20 3d 20 74 68 65 53 |..short |w = theS|
|00001120| 74 72 6f 6b 65 2d 3e 57 | 69 64 74 68 2c 20 68 20 |troke->W|idth, h |
|00001130| 3d 20 74 68 65 53 74 72 | 6f 6b 65 2d 3e 48 65 69 |= theStr|oke->Hei|
|00001140| 67 68 74 3b 0d 09 73 68 | 6f 72 74 20 78 64 20 20 |ght;..sh|ort xd |
|00001150| 3d 20 77 20 2f 20 50 52 | 45 5f 52 41 54 49 4f 5f |= w / PR|E_RATIO_|
|00001160| 58 2c 0d 09 09 09 79 64 | 20 20 3d 20 68 20 2f 20 |X,....yd| = h / |
|00001170| 50 52 45 5f 52 41 54 49 | 4f 5f 59 2c 0d 09 09 09 |PRE_RATI|O_Y,....|
|00001180| 78 64 32 20 3d 20 77 20 | 2f 20 46 49 52 53 54 5f |xd2 = w |/ FIRST_|
|00001190| 52 41 54 49 4f 5f 58 2c | 0d 09 09 09 79 64 32 20 |RATIO_X,|....yd2 |
|000011a0| 3d 20 68 20 2f 20 46 49 | 52 53 54 5f 52 41 54 49 |= h / FI|RST_RATI|
|000011b0| 4f 5f 59 3b 0d 09 64 6f | 75 62 6c 65 20 61 72 20 |O_Y;..do|uble ar |
|000011c0| 3d 20 74 68 65 53 74 72 | 6f 6b 65 2d 3e 41 73 70 |= theStr|oke->Asp|
|000011d0| 65 63 74 5f 52 61 74 69 | 6f 3b 0d 09 69 66 09 09 |ect_Rati|o;..if..|
|000011e0| 20 20 28 61 72 20 3c 20 | 30 2e 32 29 20 7b 0d 09 | (ar < |0.2) {..|
|000011f0| 09 09 74 68 65 53 74 72 | 6f 6b 65 2d 3e 50 5b 30 |..theStr|oke->P[0|
|00001200| 5d 20 3d 20 74 68 65 53 | 74 72 6f 6b 65 2d 3e 49 |] = theS|troke->I|
|00001210| 6e 6b 5b 30 5d 3b 0d 09 | 09 09 74 68 65 53 74 72 |nk[0];..|..theStr|
|00001220| 6f 6b 65 2d 3e 50 5b 31 | 5d 20 3d 20 74 68 65 53 |oke->P[1|] = theS|
|00001230| 74 72 6f 6b 65 2d 3e 49 | 6e 6b 5b 74 68 65 53 74 |troke->I|nk[theSt|
|00001240| 72 6f 6b 65 2d 3e 49 6e | 6b 5f 4e 75 6d 2f 32 5d |roke->In|k_Num/2]|
|00001250| 3b 0d 09 09 09 74 68 65 | 53 74 72 6f 6b 65 2d 3e |;....the|Stroke->|
|00001260| 50 5b 32 5d 20 3d 20 74 | 68 65 53 74 72 6f 6b 65 |P[2] = t|heStroke|
|00001270| 2d 3e 49 6e 6b 5b 74 68 | 65 53 74 72 6f 6b 65 2d |->Ink[th|eStroke-|
|00001280| 3e 49 6e 6b 5f 4e 75 6d | 20 2d 20 31 5d 3b 0d 09 |>Ink_Num| - 1];..|
|00001290| 09 09 4e 20 3d 20 33 3b | 0d 09 09 09 7d 0d 09 65 |..N = 3;|....}..e|
|000012a0| 6c 73 65 20 69 66 20 28 | 61 72 20 3e 20 35 2e 30 |lse if (|ar > 5.0|
|000012b0| 29 0d 09 09 09 4e 20 3d | 20 50 72 6f 63 65 73 73 |)....N =| Process|
|000012c0| 33 28 74 68 65 53 74 72 | 6f 6b 65 2d 3e 50 2c 49 |3(theStr|oke->P,I|
|000012d0| 6e 6b 2c 4e 2c 32 2a 77 | 2c 79 64 2c 32 2a 77 2c |nk,N,2*w|,yd,2*w,|
|000012e0| 79 64 32 29 3b 0d 09 65 | 6c 73 65 09 4e 20 3d 20 |yd2);..e|lse.N = |
|000012f0| 50 72 6f 63 65 73 73 33 | 28 74 68 65 53 74 72 6f |Process3|(theStro|
|00001300| 6b 65 2d 3e 50 2c 49 6e | 6b 2c 4e 2c 78 64 2c 79 |ke->P,In|k,N,xd,y|
|00001310| 64 2c 78 64 32 2c 79 64 | 32 29 3b 0d 09 74 68 65 |d,xd2,yd|2);..the|
|00001320| 53 74 72 6f 6b 65 2d 3e | 4e 20 3d 20 4e 3b 0d 09 |Stroke->|N = N;..|
|00001330| 7d 0d 0d 23 64 65 66 69 | 6e 65 20 44 69 72 65 63 |}..#defi|ne Direc|
|00001340| 74 69 6f 6e 41 28 74 29 | 20 28 27 30 27 20 2b 20 |tionA(t)| ('0' + |
|00001350| 28 28 74 20 2b 20 31 30 | 20 2b 20 34 35 20 2b 20 |((t + 10| + 45 + |
|00001360| 31 38 30 29 20 2f 20 39 | 30 29 20 25 20 34 29 0d |180) / 9|0) % 4).|
|00001370| 23 64 65 66 69 6e 65 20 | 44 69 72 65 63 74 69 6f |#define |Directio|
|00001380| 6e 42 28 74 29 20 28 27 | 30 27 20 2b 20 28 28 74 |nB(t) ('|0' + ((t|
|00001390| 20 2b 20 31 30 20 2b 20 | 30 30 20 2b 20 31 38 30 | + 10 + |00 + 180|
|000013a0| 29 20 2f 20 39 30 29 20 | 25 20 34 29 0d 23 64 65 |) / 90) |% 4).#de|
|000013b0| 66 69 6e 65 20 44 69 72 | 65 63 74 69 6f 6e 61 28 |fine Dir|ectiona(|
|000013c0| 74 29 20 28 27 30 27 20 | 2b 20 28 28 74 20 2b 20 |t) ('0' |+ ((t + |
|000013d0| 31 30 20 2b 20 32 32 20 | 2b 20 31 38 30 29 20 2f |10 + 22 |+ 180) /|
|000013e0| 20 39 30 29 20 25 20 34 | 29 0d 23 64 65 66 69 6e | 90) % 4|).#defin|
|000013f0| 65 20 44 69 72 65 63 74 | 69 6f 6e 62 28 74 29 20 |e Direct|ionb(t) |
|00001400| 28 27 30 27 20 2b 20 28 | 28 74 20 2b 20 31 30 20 |('0' + (|(t + 10 |
|00001410| 2d 20 32 32 20 2b 20 31 | 38 30 29 20 2f 20 39 30 |- 22 + 1|80) / 90|
|00001420| 29 20 25 20 34 29 0d 23 | 64 65 66 69 6e 65 20 44 |) % 4).#|define D|
|00001430| 69 72 65 63 74 69 6f 6e | 43 28 74 29 20 28 27 30 |irection|C(t) ('0|
|00001440| 27 20 2b 20 28 28 74 20 | 2b 20 31 30 20 2b 20 32 |' + ((t |+ 10 + 2|
|00001450| 32 20 2b 20 31 38 30 29 | 20 2f 20 34 35 29 20 25 |2 + 180)| / 45) %|
|00001460| 20 38 29 0d 23 64 65 66 | 69 6e 65 20 44 69 72 65 | 8).#def|ine Dire|
|00001470| 63 74 69 6f 6e 44 28 70 | 29 20 28 27 30 27 20 2b |ctionD(p|) ('0' +|
|00001480| 20 28 34 2a 28 28 70 29 | 2e 68 20 2d 20 74 68 65 | (4*((p)|.h - the|
|00001490| 53 74 72 6f 6b 65 2d 3e | 58 6d 69 6e 54 29 20 2f |Stroke->|XminT) /|
|000014a0| 20 74 68 65 53 74 72 6f | 6b 65 2d 3e 57 69 64 74 | theStro|ke->Widt|
|000014b0| 68 54 29 29 0d 23 64 65 | 66 69 6e 65 20 44 69 72 |hT)).#de|fine Dir|
|000014c0| 65 63 74 69 6f 6e 45 28 | 70 29 20 28 27 30 27 20 |ectionE(|p) ('0' |
|000014d0| 2b 20 28 34 2a 28 28 70 | 29 2e 76 20 2d 20 74 68 |+ (4*((p|).v - th|
|000014e0| 65 53 74 72 6f 6b 65 2d | 3e 59 6d 69 6e 54 29 20 |eStroke-|>YminT) |
|000014f0| 2f 20 74 68 65 53 74 72 | 6f 6b 65 2d 3e 48 65 69 |/ theStr|oke->Hei|
|00001500| 67 68 74 54 29 29 0d 23 | 64 65 66 69 6e 65 20 44 |ghtT)).#|define D|
|00001510| 69 72 65 63 74 69 6f 6e | 55 28 74 29 20 28 27 30 |irection|U(t) ('0|
|00001520| 27 20 2b 20 28 28 74 20 | 2b 20 30 30 20 2b 20 34 |' + ((t |+ 00 + 4|
|00001530| 35 20 2b 20 31 38 30 29 | 20 2f 20 39 30 29 20 25 |5 + 180)| / 90) %|
|00001540| 20 34 29 0d 0d 23 64 65 | 66 69 6e 65 20 46 4f 4f | 4)..#de|fine FOO|
|00001550| 28 6e 61 6d 65 2c 66 78 | 6e 2c 74 79 70 65 2c 61 |(name,fx|n,type,a|
|00001560| 72 72 61 79 2c 65 6e 64 | 29 09 09 5c 0d 76 6f 69 |rray,end|)..\.voi|
|00001570| 64 20 6e 61 6d 65 28 63 | 68 61 72 20 2a 73 2c 53 |d name(c|har *s,S|
|00001580| 74 72 6f 6b 65 50 74 72 | 20 74 68 65 53 74 72 6f |trokePtr| theStro|
|00001590| 6b 65 29 3b 09 5c 0d 76 | 6f 69 64 20 6e 61 6d 65 |ke);.\.v|oid name|
|000015a0| 28 73 2c 74 68 65 53 74 | 72 6f 6b 65 29 09 09 09 |(s,theSt|roke)...|
|000015b0| 09 09 09 09 5c 0d 20 72 | 65 67 69 73 74 65 72 20 |....\. r|egister |
|000015c0| 63 68 61 72 20 2a 73 3b | 09 09 09 09 09 09 09 09 |char *s;|........|
|000015d0| 5c 0d 20 53 74 72 6f 6b | 65 50 74 72 09 74 68 65 |\. Strok|ePtr.the|
|000015e0| 53 74 72 6f 6b 65 3b 09 | 09 09 09 09 09 09 5c 0d |Stroke;.|......\.|
|000015f0| 09 7b 09 09 09 09 09 09 | 09 09 09 09 09 09 09 5c |.{......|.......\|
|00001600| 0d 09 72 65 67 69 73 74 | 65 72 20 73 68 6f 72 74 |..regist|er short|
|00001610| 20 69 2c 64 2c 6e 20 3d | 20 30 3b 09 09 09 09 09 | i,d,n =| 0;.....|
|00001620| 5c 0d 09 72 65 67 69 73 | 74 65 72 20 74 79 70 65 |\..regis|ter type|
|00001630| 20 2a 54 20 3d 20 74 68 | 65 53 74 72 6f 6b 65 2d | *T = th|eStroke-|
|00001640| 3e 61 72 72 61 79 3b 09 | 5c 0d 09 73 5b 30 5d 20 |>array;.|\..s[0] |
|00001650| 3d 20 66 78 6e 28 2a 54 | 2b 2b 29 3b 09 09 09 09 |= fxn(*T|++);....|
|00001660| 09 09 09 09 5c 0d 09 69 | 20 3d 20 74 68 65 53 74 |....\..i| = theSt|
|00001670| 72 6f 6b 65 2d 3e 4e 20 | 2d 20 65 6e 64 3b 09 09 |roke->N |- end;..|
|00001680| 09 09 09 09 5c 0d 09 77 | 68 69 6c 65 20 28 69 2d |....\..w|hile (i-|
|00001690| 2d 20 3e 20 30 29 20 7b | 09 09 09 09 09 09 09 09 |- > 0) {|........|
|000016a0| 5c 0d 09 09 64 20 3d 20 | 66 78 6e 28 2a 54 2b 2b |\...d = |fxn(*T++|
|000016b0| 29 3b 09 09 09 09 09 09 | 09 09 5c 0d 09 09 69 66 |);......|..\...if|
|000016c0| 20 28 73 5b 6e 5d 20 21 | 3d 20 64 29 09 09 09 09 | (s[n] !|= d)....|
|000016d0| 09 09 09 09 5c 0d 09 09 | 09 73 5b 2b 2b 6e 5d 20 |....\...|.s[++n] |
|000016e0| 3d 20 64 3b 09 09 09 09 | 09 09 09 09 5c 0d 09 09 |= d;....|....\...|
|000016f0| 7d 09 09 09 09 09 09 09 | 09 09 09 09 09 5c 0d 09 |}.......|.....\..|
|00001700| 73 5b 2b 2b 6e 5d 20 3d | 20 30 3b 09 09 09 09 09 |s[++n] =| 0;.....|
|00001710| 09 09 09 09 09 5c 0d 09 | 7d 0d 0d 46 4f 4f 28 46 |.....\..|}..FOO(F|
|00001720| 78 6e 31 2c 44 69 72 65 | 63 74 69 6f 6e 41 2c 73 |xn1,Dire|ctionA,s|
|00001730| 68 6f 72 74 2c 54 2c 32 | 29 0d 46 4f 4f 28 46 78 |hort,T,2|).FOO(Fx|
|00001740| 6e 32 2c 44 69 72 65 63 | 74 69 6f 6e 42 2c 73 68 |n2,Direc|tionB,sh|
|00001750| 6f 72 74 2c 54 2c 32 29 | 0d 46 4f 4f 28 46 78 6e |ort,T,2)|.FOO(Fxn|
|00001760| 61 2c 44 69 72 65 63 74 | 69 6f 6e 61 2c 73 68 6f |a,Direct|iona,sho|
|00001770| 72 74 2c 54 2c 32 29 0d | 46 4f 4f 28 46 78 6e 62 |rt,T,2).|FOO(Fxnb|
|00001780| 2c 44 69 72 65 63 74 69 | 6f 6e 62 2c 73 68 6f 72 |,Directi|onb,shor|
|00001790| 74 2c 54 2c 32 29 0d 46 | 4f 4f 28 46 78 6e 33 2c |t,T,2).F|OO(Fxn3,|
|000017a0| 44 69 72 65 63 74 69 6f | 6e 43 2c 73 68 6f 72 74 |Directio|nC,short|
|000017b0| 2c 54 2c 32 29 0d 46 4f | 4f 28 46 78 6e 55 2c 44 |,T,2).FO|O(FxnU,D|
|000017c0| 69 72 65 63 74 69 6f 6e | 55 2c 73 68 6f 72 74 2c |irection|U,short,|
|000017d0| 55 2c 33 29 0d 46 4f 4f | 28 46 78 6e 34 2c 44 69 |U,3).FOO|(Fxn4,Di|
|000017e0| 72 65 63 74 69 6f 6e 44 | 2c 50 6f 69 6e 74 2c 50 |rectionD|,Point,P|
|000017f0| 2c 31 29 0d 46 4f 4f 28 | 46 78 6e 35 2c 44 69 72 |,1).FOO(|Fxn5,Dir|
|00001800| 65 63 74 69 6f 6e 45 2c | 50 6f 69 6e 74 2c 50 2c |ectionE,|Point,P,|
|00001810| 31 29 0d 0d 23 64 65 66 | 69 6e 65 20 44 69 72 65 |1)..#def|ine Dire|
|00001820| 63 74 69 6f 6e 63 28 70 | 29 20 27 30 27 20 2b 20 |ctionc(p|) '0' + |
|00001830| 28 28 33 2a 28 28 70 29 | 2e 68 20 2d 20 74 68 65 |((3*((p)|.h - the|
|00001840| 53 74 72 6f 6b 65 2d 3e | 58 6d 69 6e 54 29 20 2f |Stroke->|XminT) /|
|00001850| 20 74 68 65 53 74 72 6f | 6b 65 2d 3e 57 69 64 74 | theStro|ke->Widt|
|00001860| 68 54 29 20 2b 20 5c 0d | 09 33 2a 28 33 2a 28 28 |hT) + \.|.3*(3*((|
|00001870| 70 29 2e 76 20 2d 20 74 | 68 65 53 74 72 6f 6b 65 |p).v - t|heStroke|
|00001880| 2d 3e 59 6d 69 6e 54 29 | 20 2f 20 74 68 65 53 74 |->YminT)| / theSt|
|00001890| 72 6f 6b 65 2d 3e 48 65 | 69 67 68 74 54 29 29 0d |roke->He|ightT)).|
|000018a0| 0d 76 6f 69 64 20 46 78 | 6e 63 28 63 68 61 72 20 |.void Fx|nc(char |
|000018b0| 2a 73 2c 53 74 72 6f 6b | 65 50 74 72 20 74 68 65 |*s,Strok|ePtr the|
|000018c0| 53 74 72 6f 6b 65 29 3b | 0d 76 6f 69 64 20 46 78 |Stroke);|.void Fx|
|000018d0| 6e 63 28 72 65 67 69 73 | 74 65 72 20 63 68 61 72 |nc(regis|ter char|
|000018e0| 20 2a 73 2c 53 74 72 6f | 6b 65 50 74 72 20 74 68 | *s,Stro|kePtr th|
|000018f0| 65 53 74 72 6f 6b 65 29 | 0d 09 7b 0d 09 72 65 67 |eStroke)|..{..reg|
|00001900| 69 73 74 65 72 20 73 68 | 6f 72 74 20 69 3d 20 74 |ister sh|ort i= t|
|00001910| 68 65 53 74 72 6f 6b 65 | 2d 3e 4e 20 2d 20 31 2c |heStroke|->N - 1,|
|00001920| 64 2c 6e 20 3d 20 2d 31 | 3b 0d 09 72 65 67 69 73 |d,n = -1|;..regis|
|00001930| 74 65 72 20 50 6f 69 6e | 74 20 70 2c 2a 54 20 3d |ter Poin|t p,*T =|
|00001940| 20 74 68 65 53 74 72 6f | 6b 65 2d 3e 50 3b 0d 09 | theStro|ke->P;..|
|00001950| 77 68 69 6c 65 20 28 69 | 2d 2d 20 3e 20 30 29 20 |while (i|-- > 0) |
|00001960| 7b 0d 09 09 70 20 3d 20 | 2a 54 2b 2b 3b 0d 09 09 |{...p = |*T++;...|
|00001970| 64 20 3d 20 44 69 72 65 | 63 74 69 6f 6e 63 28 70 |d = Dire|ctionc(p|
|00001980| 29 3b 0d 09 09 69 66 20 | 28 64 20 3d 3d 20 27 34 |);...if |(d == '4|
|00001990| 27 29 20 63 6f 6e 74 69 | 6e 75 65 3b 0d 09 09 69 |') conti|nue;...i|
|000019a0| 66 20 28 64 20 3e 20 27 | 34 27 29 20 64 20 2d 3d |f (d > '|4') d -=|
|000019b0| 20 31 3b 0d 09 09 69 66 | 20 28 6e 20 3d 3d 20 2d | 1;...if| (n == -|
|000019c0| 31 20 7c 7c 20 73 5b 6e | 5d 20 21 3d 20 64 29 0d |1 || s[n|] != d).|
|000019d0| 09 09 09 73 5b 2b 2b 6e | 5d 20 3d 20 64 3b 0d 09 |...s[++n|] = d;..|
|000019e0| 09 7d 0d 09 73 5b 2b 2b | 6e 5d 20 3d 20 30 3b 0d |.}..s[++|n] = 0;.|
|000019f0| 09 7d 0d 0d 23 64 65 66 | 69 6e 65 20 44 69 72 65 |.}..#def|ine Dire|
|00001a00| 63 74 69 6f 6e 64 28 70 | 29 20 27 30 27 20 2b 20 |ctiond(p|) '0' + |
|00001a10| 28 28 32 2a 28 28 70 29 | 2e 68 20 2d 20 74 68 65 |((2*((p)|.h - the|
|00001a20| 53 74 72 6f 6b 65 2d 3e | 58 6d 69 6e 54 29 20 2f |Stroke->|XminT) /|
|00001a30| 20 74 68 65 53 74 72 6f | 6b 65 2d 3e 57 69 64 74 | theStro|ke->Widt|
|00001a40| 68 54 29 20 2b 20 5c 0d | 09 32 2a 28 32 2a 28 28 |hT) + \.|.2*(2*((|
|00001a50| 70 29 2e 76 20 2d 20 74 | 68 65 53 74 72 6f 6b 65 |p).v - t|heStroke|
|00001a60| 2d 3e 59 6d 69 6e 54 29 | 20 2f 20 74 68 65 53 74 |->YminT)| / theSt|
|00001a70| 72 6f 6b 65 2d 3e 48 65 | 69 67 68 74 54 29 29 0d |roke->He|ightT)).|
|00001a80| 23 64 65 66 69 6e 65 20 | 49 4e 5f 4d 49 44 44 4c |#define |IN_MIDDL|
|00001a90| 45 28 70 29 20 28 44 69 | 72 65 63 74 69 6f 6e 63 |E(p) (Di|rectionc|
|00001aa0| 28 70 29 20 3d 3d 20 27 | 34 27 29 0d 76 6f 69 64 |(p) == '|4').void|
|00001ab0| 20 46 78 6e 64 28 63 68 | 61 72 20 2a 73 2c 53 74 | Fxnd(ch|ar *s,St|
|00001ac0| 72 6f 6b 65 50 74 72 20 | 74 68 65 53 74 72 6f 6b |rokePtr |theStrok|
|00001ad0| 65 29 3b 0d 76 6f 69 64 | 20 46 78 6e 64 28 72 65 |e);.void| Fxnd(re|
|00001ae0| 67 69 73 74 65 72 20 63 | 68 61 72 20 2a 73 2c 53 |gister c|har *s,S|
|00001af0| 74 72 6f 6b 65 50 74 72 | 20 74 68 65 53 74 72 6f |trokePtr| theStro|
|00001b00| 6b 65 29 0d 09 7b 0d 09 | 72 65 67 69 73 74 65 72 |ke)..{..|register|
|00001b10| 20 73 68 6f 72 74 20 69 | 3d 20 74 68 65 53 74 72 | short i|= theStr|
|00001b20| 6f 6b 65 2d 3e 4e 20 2d | 20 31 2c 64 2c 6e 20 3d |oke->N -| 1,d,n =|
|00001b30| 20 2d 31 3b 0d 09 72 65 | 67 69 73 74 65 72 20 50 | -1;..re|gister P|
|00001b40| 6f 69 6e 74 20 70 2c 2a | 54 20 3d 20 74 68 65 53 |oint p,*|T = theS|
|00001b50| 74 72 6f 6b 65 2d 3e 50 | 3b 0d 09 77 68 69 6c 65 |troke->P|;..while|
|00001b60| 20 28 69 2d 2d 20 3e 20 | 30 29 20 7b 0d 09 09 70 | (i-- > |0) {...p|
|00001b70| 20 3d 20 2a 54 2b 2b 3b | 0d 09 09 64 20 3d 20 44 | = *T++;|...d = D|
|00001b80| 69 72 65 63 74 69 6f 6e | 64 28 70 29 3b 0d 09 09 |irection|d(p);...|
|00001b90| 69 66 20 28 49 4e 5f 4d | 49 44 44 4c 45 28 70 29 |if (IN_M|IDDLE(p)|
|00001ba0| 29 20 63 6f 6e 74 69 6e | 75 65 3b 0d 09 09 69 66 |) contin|ue;...if|
|00001bb0| 20 28 6e 20 3d 3d 20 2d | 31 20 7c 7c 20 73 5b 6e | (n == -|1 || s[n|
|00001bc0| 5d 20 21 3d 20 64 29 0d | 09 09 09 73 5b 2b 2b 6e |] != d).|...s[++n|
|00001bd0| 5d 20 3d 20 64 3b 0d 09 | 09 7d 0d 09 73 5b 2b 2b |] = d;..|.}..s[++|
|00001be0| 6e 5d 20 3d 20 30 3b 0d | 09 7d 0d 0d 76 6f 69 64 |n] = 0;.|.}..void|
|00001bf0| 20 43 6f 6d 70 75 74 65 | 54 28 74 68 65 53 74 72 | Compute|T(theStr|
|00001c00| 6f 6b 65 29 0d 20 53 74 | 72 6f 6b 65 50 74 72 20 |oke). St|rokePtr |
|00001c10| 74 68 65 53 74 72 6f 6b | 65 3b 0d 09 7b 0d 09 72 |theStrok|e;..{..r|
|00001c20| 65 67 69 73 74 65 72 20 | 73 68 6f 72 74 20 2a 54 |egister |short *T|
|00001c30| 20 20 3d 20 74 68 65 53 | 74 72 6f 6b 65 2d 3e 54 | = theS|troke->T|
|00001c40| 3b 0d 09 72 65 67 69 73 | 74 65 72 20 73 68 6f 72 |;..regis|ter shor|
|00001c50| 74 20 2a 55 20 20 3d 20 | 74 68 65 53 74 72 6f 6b |t *U = |theStrok|
|00001c60| 65 2d 3e 55 3b 0d 09 72 | 65 67 69 73 74 65 72 20 |e->U;..r|egister |
|00001c70| 50 6f 69 6e 74 20 2a 50 | 20 20 3d 20 74 68 65 53 |Point *P| = theS|
|00001c80| 74 72 6f 6b 65 2d 3e 50 | 3b 0d 09 72 65 67 69 73 |troke->P|;..regis|
|00001c90| 74 65 72 20 73 68 6f 72 | 74 20 69 2c 4e 20 3d 20 |ter shor|t i,N = |
|00001ca0| 74 68 65 53 74 72 6f 6b | 65 2d 3e 4e 3b 0d 09 66 |theStrok|e->N;..f|
|00001cb0| 6f 72 20 28 69 20 3d 20 | 30 3b 20 69 20 3c 20 4e |or (i = |0; i < N|
|00001cc0| 20 2d 20 31 3b 20 69 2b | 2b 29 0d 09 09 54 5b 69 | - 1; i+|+)...T[i|
|00001cd0| 5d 20 3d 20 41 54 41 4e | 32 28 50 5b 69 2b 31 5d |] = ATAN|2(P[i+1]|
|00001ce0| 2e 76 2d 50 5b 69 5d 2e | 76 2c 50 5b 69 2b 31 5d |.v-P[i].|v,P[i+1]|
|00001cf0| 2e 68 2d 50 5b 69 5d 2e | 68 29 3b 0d 09 54 5b 4e |.h-P[i].|h);..T[N|
|00001d00| 2d 31 5d 20 3d 20 54 5b | 4e 2d 32 5d 3b 0d 09 66 |-1] = T[|N-2];..f|
|00001d10| 6f 72 20 28 69 20 3d 20 | 30 3b 20 69 20 3c 20 4e |or (i = |0; i < N|
|00001d20| 20 2d 20 32 3b 20 69 2b | 2b 29 0d 09 09 55 5b 69 | - 2; i+|+)...U[i|
|00001d30| 5d 20 3d 20 44 74 28 54 | 5b 69 5d 2c 54 5b 69 2b |] = Dt(T|[i],T[i+|
|00001d40| 31 5d 29 3b 0d 09 7d 0d | 0d 76 6f 69 64 20 41 6e |1]);..}.|.void An|
|00001d50| 61 6c 79 7a 65 28 74 68 | 65 53 74 72 6f 6b 65 29 |alyze(th|eStroke)|
|00001d60| 0d 20 72 65 67 69 73 74 | 65 72 20 53 74 72 6f 6b |. regist|er Strok|
|00001d70| 65 50 74 72 20 74 68 65 | 53 74 72 6f 6b 65 3b 0d |ePtr the|Stroke;.|
|00001d80| 09 7b 0d 09 63 68 61 72 | 20 73 5b 31 30 30 5d 3b |.{..char| s[100];|
|00001d90| 0d 09 72 65 67 69 73 74 | 65 72 20 73 68 6f 72 74 |..regist|er short|
|00001da0| 20 2a 54 20 3d 20 74 68 | 65 53 74 72 6f 6b 65 2d | *T = th|eStroke-|
|00001db0| 3e 54 3b 0d 09 72 65 67 | 69 73 74 65 72 20 50 6f |>T;..reg|ister Po|
|00001dc0| 69 6e 74 20 2a 50 20 3d | 20 74 68 65 53 74 72 6f |int *P =| theStro|
|00001dd0| 6b 65 2d 3e 50 3b 0d 09 | 72 65 67 69 73 74 65 72 |ke->P;..|register|
|00001de0| 20 73 68 6f 72 74 20 20 | 4e 20 3d 20 74 68 65 53 | short |N = theS|
|00001df0| 74 72 6f 6b 65 2d 3e 4e | 3b 0d 09 73 68 6f 72 74 |troke->N|;..short|
|00001e00| 20 48 65 69 67 68 74 20 | 3d 20 74 68 65 53 74 72 | Height |= theStr|
|00001e10| 6f 6b 65 2d 3e 48 65 69 | 67 68 74 2c 0d 09 09 09 |oke->Hei|ght,....|
|00001e20| 57 69 64 74 68 20 20 3d | 20 74 68 65 53 74 72 6f |Width =| theStro|
|00001e30| 6b 65 2d 3e 57 69 64 74 | 68 2c 69 3b 0d 0d 09 69 |ke->Widt|h,i;...i|
|00001e40| 66 20 28 53 74 72 6f 6b | 65 73 29 0d 09 09 7b 0d |f (Strok|es)...{.|
|00001e50| 09 20 09 53 74 72 6f 6b | 65 50 74 72 09 6c 61 73 |. .Strok|ePtr.las|
|00001e60| 74 53 74 72 6f 6b 65 20 | 3d 20 53 74 72 6f 6b 65 |tStroke |= Stroke|
|00001e70| 73 2d 3e 69 74 65 6d 73 | 5b 53 74 72 6f 6b 65 73 |s->items|[Strokes|
|00001e80| 2d 3e 6e 75 6d 5f 69 74 | 65 6d 73 20 2d 20 31 5d |->num_it|ems - 1]|
|00001e90| 3b 0d 09 20 09 50 6f 69 | 6e 74 20 6c 61 73 74 50 |;.. .Poi|nt lastP|
|00001ea0| 6f 69 6e 74 20 3d 20 6c | 61 73 74 53 74 72 6f 6b |oint = l|astStrok|
|00001eb0| 65 2d 3e 50 5b 6c 61 73 | 74 53 74 72 6f 6b 65 2d |e->P[las|tStroke-|
|00001ec0| 3e 4e 20 2d 20 31 5d 3b | 0d 09 20 09 0d 09 09 74 |>N - 1];|.. ....t|
|00001ed0| 68 65 53 74 72 6f 6b 65 | 2d 3e 58 6d 61 78 54 20 |heStroke|->XmaxT |
|00001ee0| 3d 20 4d 41 58 28 74 68 | 65 53 74 72 6f 6b 65 2d |= MAX(th|eStroke-|
|00001ef0| 3e 58 6d 61 78 2c 6c 61 | 73 74 53 74 72 6f 6b 65 |>Xmax,la|stStroke|
|00001f00| 2d 3e 58 6d 61 78 54 29 | 3b 0d 09 09 74 68 65 53 |->XmaxT)|;...theS|
|00001f10| 74 72 6f 6b 65 2d 3e 58 | 6d 69 6e 54 20 3d 20 4d |troke->X|minT = M|
|00001f20| 49 4e 28 74 68 65 53 74 | 72 6f 6b 65 2d 3e 58 6d |IN(theSt|roke->Xm|
|00001f30| 69 6e 2c 6c 61 73 74 53 | 74 72 6f 6b 65 2d 3e 58 |in,lastS|troke->X|
|00001f40| 6d 69 6e 54 29 3b 0d 09 | 09 74 68 65 53 74 72 6f |minT);..|.theStro|
|00001f50| 6b 65 2d 3e 59 6d 61 78 | 54 20 3d 20 4d 41 58 28 |ke->Ymax|T = MAX(|
|00001f60| 74 68 65 53 74 72 6f 6b | 65 2d 3e 59 6d 61 78 2c |theStrok|e->Ymax,|
|00001f70| 6c 61 73 74 53 74 72 6f | 6b 65 2d 3e 59 6d 61 78 |lastStro|ke->Ymax|
|00001f80| 54 29 3b 0d 09 09 74 68 | 65 53 74 72 6f 6b 65 2d |T);...th|eStroke-|
|00001f90| 3e 59 6d 69 6e 54 20 3d | 20 4d 49 4e 28 74 68 65 |>YminT =| MIN(the|
|00001fa0| 53 74 72 6f 6b 65 2d 3e | 59 6d 69 6e 2c 6c 61 73 |Stroke->|Ymin,las|
|00001fb0| 74 53 74 72 6f 6b 65 2d | 3e 59 6d 69 6e 54 29 3b |tStroke-|>YminT);|
|00001fc0| 0d 09 09 74 68 65 53 74 | 72 6f 6b 65 2d 3e 48 65 |...theSt|roke->He|
|00001fd0| 69 67 68 74 54 20 3d 20 | 28 74 68 65 53 74 72 6f |ightT = |(theStro|
|00001fe0| 6b 65 2d 3e 59 6d 61 78 | 54 20 2d 20 74 68 65 53 |ke->Ymax|T - theS|
|00001ff0| 74 72 6f 6b 65 2d 3e 59 | 6d 69 6e 54 20 2b 20 31 |troke->Y|minT + 1|
|00002000| 29 3b 0d 09 09 74 68 65 | 53 74 72 6f 6b 65 2d 3e |);...the|Stroke->|
|00002010| 57 69 64 74 68 54 20 3d | 20 28 74 68 65 53 74 72 |WidthT =| (theStr|
|00002020| 6f 6b 65 2d 3e 58 6d 61 | 78 54 20 2d 20 74 68 65 |oke->Xma|xT - the|
|00002030| 53 74 72 6f 6b 65 2d 3e | 58 6d 69 6e 54 20 2b 20 |Stroke->|XminT + |
|00002040| 31 29 3b 0d 09 09 7d 0d | 09 65 6c 73 65 20 7b 0d |1);...}.|.else {.|
|00002050| 09 09 74 68 65 53 74 72 | 6f 6b 65 2d 3e 58 6d 61 |..theStr|oke->Xma|
|00002060| 78 54 20 3d 20 74 68 65 | 53 74 72 6f 6b 65 2d 3e |xT = the|Stroke->|
|00002070| 58 6d 61 78 3b 0d 09 09 | 74 68 65 53 74 72 6f 6b |Xmax;...|theStrok|
|00002080| 65 2d 3e 58 6d 69 6e 54 | 20 3d 20 74 68 65 53 74 |e->XminT| = theSt|
|00002090| 72 6f 6b 65 2d 3e 58 6d | 69 6e 3b 0d 09 09 74 68 |roke->Xm|in;...th|
|000020a0| 65 53 74 72 6f 6b 65 2d | 3e 59 6d 61 78 54 20 3d |eStroke-|>YmaxT =|
|000020b0| 20 74 68 65 53 74 72 6f | 6b 65 2d 3e 59 6d 61 78 | theStro|ke->Ymax|
|000020c0| 3b 0d 09 09 74 68 65 53 | 74 72 6f 6b 65 2d 3e 59 |;...theS|troke->Y|
|000020d0| 6d 69 6e 54 20 3d 20 74 | 68 65 53 74 72 6f 6b 65 |minT = t|heStroke|
|000020e0| 2d 3e 59 6d 69 6e 3b 0d | 09 09 74 68 65 53 74 72 |->Ymin;.|..theStr|
|000020f0| 6f 6b 65 2d 3e 48 65 69 | 67 68 74 54 20 3d 20 74 |oke->Hei|ghtT = t|
|00002100| 68 65 53 74 72 6f 6b 65 | 2d 3e 48 65 69 67 68 74 |heStroke|->Height|
|00002110| 3b 0d 09 09 74 68 65 53 | 74 72 6f 6b 65 2d 3e 57 |;...theS|troke->W|
|00002120| 69 64 74 68 54 20 3d 20 | 74 68 65 53 74 72 6f 6b |idthT = |theStrok|
|00002130| 65 2d 3e 57 69 64 74 68 | 3b 0d 09 09 7d 0d 0d 09 |e->Width|;...}...|
|00002140| 43 6f 6d 70 75 74 65 54 | 28 74 68 65 53 74 72 6f |ComputeT|(theStro|
|00002150| 6b 65 29 3b 0d 09 66 6f | 72 20 28 69 3d 30 3b 69 |ke);..fo|r (i=0;i|
|00002160| 3c 4e 55 4d 5f 46 45 41 | 54 55 52 45 53 3b 69 2b |<NUM_FEA|TURES;i+|
|00002170| 2b 29 20 7b 0d 09 09 28 | 2a 48 61 73 68 46 75 6e |+) {...(|*HashFun|
|00002180| 63 74 69 6f 6e 73 5b 69 | 5d 29 28 73 2c 74 68 65 |ctions[i|])(s,the|
|00002190| 53 74 72 6f 6b 65 29 3b | 0d 09 09 43 6f 6e 76 65 |Stroke);|...Conve|
|000021a0| 72 74 53 74 72 69 6e 67 | 54 6f 4c 6f 6e 67 28 73 |rtString|ToLong(s|
|000021b0| 2c 26 74 68 65 53 74 72 | 6f 6b 65 2d 3e 53 5b 69 |,&theStr|oke->S[i|
|000021c0| 5d 2c 42 69 74 73 5b 69 | 5d 29 3b 0d 09 09 7d 0d |],Bits[i|]);...}.|
|000021d0| 09 74 68 65 53 74 72 6f | 6b 65 2d 3e 49 73 44 6f |.theStro|ke->IsDo|
|000021e0| 74 20 3d 20 28 28 48 65 | 69 67 68 74 20 3c 20 44 |t = ((He|ight < D|
|000021f0| 4f 54 5f 54 48 52 45 53 | 48 48 4f 4c 44 20 26 26 |OT_THRES|HHOLD &&|
|00002200| 20 57 69 64 74 68 20 3c | 20 44 4f 54 5f 54 48 52 | Width <| DOT_THR|
|00002210| 45 53 48 48 4f 4c 44 29 | 20 7c 7c 20 4e 20 3d 3d |ESHHOLD)| || N ==|
|00002220| 20 31 29 3b 0d 09 7d 0d | 0d 76 6f 69 64 20 43 6f | 1);..}.|.void Co|
|00002230| 6d 70 75 74 65 42 42 6f | 78 28 29 0d 09 7b 0d 09 |mputeBBo|x()..{..|
|00002240| 6c 6f 6e 67 20 58 6d 61 | 78 2c 58 6d 69 6e 2c 59 |long Xma|x,Xmin,Y|
|00002250| 6d 61 78 2c 59 6d 69 6e | 3b 0d 09 73 68 6f 72 74 |max,Ymin|;..short|
|00002260| 09 09 09 69 3b 0d 20 09 | 53 74 72 6f 6b 65 50 74 |...i;. .|StrokePt|
|00002270| 72 09 74 68 65 53 74 72 | 6f 6b 65 3b 0d 20 09 0d |r.theStr|oke;. ..|
|00002280| 09 74 68 65 53 74 72 6f | 6b 65 20 3d 20 53 74 72 |.theStro|ke = Str|
|00002290| 6f 6b 65 73 2d 3e 69 74 | 65 6d 73 5b 30 5d 3b 0d |okes->it|ems[0];.|
|000022a0| 09 58 6d 61 78 20 3d 20 | 74 68 65 53 74 72 6f 6b |.Xmax = |theStrok|
|000022b0| 65 2d 3e 58 6d 61 78 3b | 20 58 6d 69 6e 20 3d 20 |e->Xmax;| Xmin = |
|000022c0| 74 68 65 53 74 72 6f 6b | 65 2d 3e 58 6d 69 6e 3b |theStrok|e->Xmin;|
|000022d0| 0d 09 59 6d 61 78 20 3d | 20 74 68 65 53 74 72 6f |..Ymax =| theStro|
|000022e0| 6b 65 2d 3e 59 6d 61 78 | 3b 20 59 6d 69 6e 20 3d |ke->Ymax|; Ymin =|
|000022f0| 20 74 68 65 53 74 72 6f | 6b 65 2d 3e 59 6d 69 6e | theStro|ke->Ymin|
|00002300| 3b 0d 0d 09 66 6f 72 20 | 28 69 20 3d 20 31 3b 20 |;...for |(i = 1; |
|00002310| 69 20 3c 20 53 74 72 6f | 6b 65 73 2d 3e 6e 75 6d |i < Stro|kes->num|
|00002320| 5f 69 74 65 6d 73 3b 20 | 69 2b 2b 29 20 7b 0d 09 |_items; |i++) {..|
|00002330| 09 74 68 65 53 74 72 6f | 6b 65 20 3d 20 53 74 72 |.theStro|ke = Str|
|00002340| 6f 6b 65 73 2d 3e 69 74 | 65 6d 73 5b 69 5d 3b 0d |okes->it|ems[i];.|
|00002350| 09 09 69 66 20 28 74 68 | 65 53 74 72 6f 6b 65 2d |..if (th|eStroke-|
|00002360| 3e 58 6d 61 78 20 3e 20 | 58 6d 61 78 29 20 58 6d |>Xmax > |Xmax) Xm|
|00002370| 61 78 20 3d 20 74 68 65 | 53 74 72 6f 6b 65 2d 3e |ax = the|Stroke->|
|00002380| 58 6d 61 78 3b 0d 09 09 | 69 66 20 28 74 68 65 53 |Xmax;...|if (theS|
|00002390| 74 72 6f 6b 65 2d 3e 59 | 6d 61 78 20 3e 20 59 6d |troke->Y|max > Ym|
|000023a0| 61 78 29 20 59 6d 61 78 | 20 3d 20 74 68 65 53 74 |ax) Ymax| = theSt|
|000023b0| 72 6f 6b 65 2d 3e 59 6d | 61 78 3b 0d 09 09 69 66 |roke->Ym|ax;...if|
|000023c0| 20 28 74 68 65 53 74 72 | 6f 6b 65 2d 3e 58 6d 69 | (theStr|oke->Xmi|
|000023d0| 6e 20 3c 20 58 6d 69 6e | 29 20 58 6d 69 6e 20 3d |n < Xmin|) Xmin =|
|000023e0| 20 74 68 65 53 74 72 6f | 6b 65 2d 3e 58 6d 69 6e | theStro|ke->Xmin|
|000023f0| 3b 0d 09 09 69 66 20 28 | 74 68 65 53 74 72 6f 6b |;...if (|theStrok|
|00002400| 65 2d 3e 59 6d 69 6e 20 | 3c 20 59 6d 69 6e 29 20 |e->Ymin |< Ymin) |
|00002410| 59 6d 69 6e 20 3d 20 74 | 68 65 53 74 72 6f 6b 65 |Ymin = t|heStroke|
|00002420| 2d 3e 59 6d 69 6e 3b 0d | 09 09 7d 0d 0d 09 69 66 |->Ymin;.|..}...if|
|00002430| 20 28 57 61 63 6f 6d 29 | 20 7b 0d 09 09 42 42 6f | (Wacom)| {...BBo|
|00002440| 78 2e 74 6f 70 09 09 3d | 20 54 41 42 5f 54 4f 5f |x.top..=| TAB_TO_|
|00002450| 53 43 52 45 45 4e 5f 59 | 28 59 6d 69 6e 29 3b 0d |SCREEN_Y|(Ymin);.|
|00002460| 09 09 42 42 6f 78 2e 62 | 6f 74 74 6f 6d 09 3d 20 |..BBox.b|ottom.= |
|00002470| 54 41 42 5f 54 4f 5f 53 | 43 52 45 45 4e 5f 59 28 |TAB_TO_S|CREEN_Y(|
|00002480| 59 6d 61 78 29 3b 0d 09 | 09 42 42 6f 78 2e 6c 65 |Ymax);..|.BBox.le|
|00002490| 66 74 09 3d 20 54 41 42 | 5f 54 4f 5f 53 43 52 45 |ft.= TAB|_TO_SCRE|
|000024a0| 45 4e 5f 58 28 58 6d 69 | 6e 29 3b 0d 09 09 42 42 |EN_X(Xmi|n);...BB|
|000024b0| 6f 78 2e 72 69 67 68 74 | 09 3d 20 54 41 42 5f 54 |ox.right|.= TAB_T|
|000024c0| 4f 5f 53 43 52 45 45 4e | 5f 58 28 58 6d 61 78 29 |O_SCREEN|_X(Xmax)|
|000024d0| 3b 0d 09 09 47 6c 6f 62 | 61 6c 54 6f 4c 6f 63 61 |;...Glob|alToLoca|
|000024e0| 6c 28 26 74 6f 70 4c 65 | 66 74 28 42 42 6f 78 29 |l(&topLe|ft(BBox)|
|000024f0| 29 3b 0d 09 09 47 6c 6f | 62 61 6c 54 6f 4c 6f 63 |);...Glo|balToLoc|
|00002500| 61 6c 28 26 62 6f 74 52 | 69 67 68 74 28 42 42 6f |al(&botR|ight(BBo|
|00002510| 78 29 29 3b 0d 09 09 7d | 0d 09 65 6c 73 65 20 7b |x));...}|..else {|
|00002520| 0d 09 09 42 42 6f 78 2e | 74 6f 70 09 09 3d 20 59 |...BBox.|top..= Y|
|00002530| 6d 69 6e 3b 0d 09 09 42 | 42 6f 78 2e 62 6f 74 74 |min;...B|Box.bott|
|00002540| 6f 6d 09 3d 20 59 6d 61 | 78 3b 0d 09 09 42 42 6f |om.= Yma|x;...BBo|
|00002550| 78 2e 6c 65 66 74 09 3d | 20 58 6d 69 6e 3b 0d 09 |x.left.=| Xmin;..|
|00002560| 09 42 42 6f 78 2e 72 69 | 67 68 74 09 3d 20 58 6d |.BBox.ri|ght.= Xm|
|00002570| 61 78 3b 0d 09 09 7d 0d | 09 7d 0d 0d 73 68 6f 72 |ax;...}.|.}..shor|
|00002580| 74 20 53 74 72 6f 6b 65 | 4d 61 79 43 6f 6e 74 69 |t Stroke|MayConti|
|00002590| 6e 75 65 28 76 6f 69 64 | 29 3b 0d 73 68 6f 72 74 |nue(void|);.short|
|000025a0| 20 53 74 72 6f 6b 65 4d | 61 79 43 6f 6e 74 69 6e | StrokeM|ayContin|
|000025b0| 75 65 28 29 0d 09 7b 0d | 09 47 65 73 74 75 72 65 |ue()..{.|.Gesture|
|000025c0| 50 61 74 74 65 72 6e 20 | 2a 67 70 3b 0d 09 73 68 |Pattern |*gp;..sh|
|000025d0| 6f 72 74 20 69 2c 69 6e | 64 65 78 3b 0d 09 53 74 |ort i,in|dex;..St|
|000025e0| 72 6f 6b 65 50 74 72 20 | 6c 61 73 74 53 74 72 6f |rokePtr |lastStro|
|000025f0| 6b 65 20 3d 20 53 74 72 | 6f 6b 65 73 2d 3e 69 74 |ke = Str|okes->it|
|00002600| 65 6d 73 5b 53 74 72 6f | 6b 65 73 2d 3e 6e 75 6d |ems[Stro|kes->num|
|00002610| 5f 69 74 65 6d 73 20 2d | 20 31 5d 3b 0d 09 4c 69 |_items -| 1];..Li|
|00002620| 73 74 20 6d 61 74 63 68 | 65 73 20 3d 20 6c 61 73 |st match|es = las|
|00002630| 74 53 74 72 6f 6b 65 2d | 3e 6d 61 74 63 68 65 73 |tStroke-|>matches|
|00002640| 3b 0d 09 0d 09 69 66 20 | 28 6d 61 74 63 68 65 73 |;....if |(matches|
|00002650| 20 3d 3d 20 4e 49 4c 29 | 20 72 65 74 75 72 6e 20 | == NIL)| return |
|00002660| 46 41 4c 53 45 3b 0d 09 | 69 66 20 28 6d 61 74 63 |FALSE;..|if (matc|
|00002670| 68 65 73 2d 3e 6e 75 6d | 5f 69 74 65 6d 73 20 3d |hes->num|_items =|
|00002680| 3d 20 30 29 20 72 65 74 | 75 72 6e 20 46 41 4c 53 |= 0) ret|urn FALS|
|00002690| 45 3b 0d 09 0d 09 66 6f | 72 20 28 69 20 3d 20 30 |E;....fo|r (i = 0|
|000026a0| 3b 20 69 20 3c 20 6d 61 | 74 63 68 65 73 2d 3e 6e |; i < ma|tches->n|
|000026b0| 75 6d 5f 69 74 65 6d 73 | 3b 20 69 2b 2b 29 20 7b |um_items|; i++) {|
|000026c0| 0d 09 09 69 6e 64 65 78 | 20 3d 20 28 6c 6f 6e 67 |...index| = (long|
|000026d0| 29 6d 61 74 63 68 65 73 | 2d 3e 69 74 65 6d 73 5b |)matches|->items[|
|000026e0| 69 5d 20 26 20 30 78 46 | 46 46 46 3b 0d 09 09 67 |i] & 0xF|FFF;...g|
|000026f0| 70 20 3d 20 70 61 74 74 | 65 72 6e 73 2d 3e 69 74 |p = patt|erns->it|
|00002700| 65 6d 73 5b 69 6e 64 65 | 78 5d 3b 0d 09 09 69 66 |ems[inde|x];...if|
|00002710| 20 28 67 70 2d 3e 73 74 | 72 6f 6b 65 73 2d 3e 6e | (gp->st|rokes->n|
|00002720| 75 6d 5f 69 74 65 6d 73 | 20 3e 20 53 74 72 6f 6b |um_items| > Strok|
|00002730| 65 73 2d 3e 6e 75 6d 5f | 69 74 65 6d 73 29 0d 09 |es->num_|items)..|
|00002740| 09 09 72 65 74 75 72 6e | 20 54 52 55 45 3b 0d 09 |..return| TRUE;..|
|00002750| 09 7d 0d 09 72 65 74 75 | 72 6e 20 46 41 4c 53 45 |.}..retu|rn FALSE|
|00002760| 3b 0d 09 7d 0d 0d 73 68 | 6f 72 74 20 54 72 79 43 |;..}..sh|ort TryC|
|00002770| 6f 6c 6c 65 63 74 47 65 | 73 74 75 72 65 28 77 68 |ollectGe|sture(wh|
|00002780| 65 72 65 2c 77 68 65 6e | 29 0d 20 50 6f 69 6e 74 |ere,when|). Point|
|00002790| 20 77 68 65 72 65 3b 0d | 20 6c 6f 6e 67 09 77 68 | where;.| long.wh|
|000027a0| 65 6e 3b 0d 09 7b 0d 09 | 73 68 6f 72 74 09 09 09 |en;..{..|short...|
|000027b0| 69 2c 6a 2c 63 6f 64 65 | 3b 0d 20 09 53 74 72 6f |i,j,code|;. .Stro|
|000027c0| 6b 65 50 74 72 09 74 68 | 65 53 74 72 6f 6b 65 3b |kePtr.th|eStroke;|
|000027d0| 0d 20 0d 09 46 72 65 65 | 53 74 72 6f 6b 65 73 28 |. ..Free|Strokes(|
|000027e0| 29 3b 0d 20 09 74 68 65 | 53 74 72 6f 6b 65 20 3d |);. .the|Stroke =|
|000027f0| 20 63 61 6c 6c 6f 63 28 | 31 2c 73 69 7a 65 6f 66 | calloc(|1,sizeof|
|00002800| 28 53 74 72 6f 6b 65 44 | 61 74 61 29 29 3b 0d 09 |(StrokeD|ata));..|
|00002810| 69 66 20 28 74 68 65 53 | 74 72 6f 6b 65 20 3d 3d |if (theS|troke ==|
|00002820| 20 4e 49 4c 29 20 7b 53 | 79 73 42 65 65 70 28 31 | NIL) {S|ysBeep(1|
|00002830| 29 3b 20 44 65 62 75 67 | 67 65 72 28 29 3b 20 45 |); Debug|ger(); E|
|00002840| 78 69 74 54 6f 53 68 65 | 6c 6c 28 29 3b 7d 0d 20 |xitToShe|ll();}. |
|00002850| 09 74 68 65 53 74 72 6f | 6b 65 2d 3e 73 74 61 72 |.theStro|ke->star|
|00002860| 74 5f 74 69 6d 65 20 3d | 20 77 68 65 6e 3b 0d 09 |t_time =| when;..|
|00002870| 69 66 20 28 43 6f 6c 6c | 65 63 74 53 74 72 6f 6b |if (Coll|ectStrok|
|00002880| 65 28 77 68 65 72 65 2c | 74 68 65 53 74 72 6f 6b |e(where,|theStrok|
|00002890| 65 29 29 0d 09 09 7b 0d | 09 09 69 66 20 28 50 61 |e))...{.|..if (Pa|
|000028a0| 75 73 65 49 73 4d 6f 75 | 73 65 29 20 7b 0d 09 09 |useIsMou|se) {...|
|000028b0| 09 66 72 65 65 28 74 68 | 65 53 74 72 6f 6b 65 29 |.free(th|eStroke)|
|000028c0| 3b 0d 09 09 09 72 65 74 | 75 72 6e 20 2d 31 3b 0d |;....ret|urn -1;.|
|000028d0| 09 09 09 7d 0d 09 09 7d | 0d 0d 09 46 6c 75 73 68 |...}...}|...Flush|
|000028e0| 45 76 65 6e 74 73 28 65 | 76 65 72 79 45 76 65 6e |Events(e|veryEven|
|000028f0| 74 2c 30 29 3b 0d 09 41 | 70 70 65 6e 64 28 26 53 |t,0);..A|ppend(&S|
|00002900| 74 72 6f 6b 65 73 2c 28 | 6c 6f 6e 67 29 74 68 65 |trokes,(|long)the|
|00002910| 53 74 72 6f 6b 65 29 3b | 0d 09 52 65 63 6f 67 6e |Stroke);|..Recogn|
|00002920| 69 7a 65 53 74 72 6f 6b | 65 28 30 29 3b 0d 09 77 |izeStrok|e(0);..w|
|00002930| 68 69 6c 65 20 28 49 4e | 5f 50 52 4f 58 49 4d 49 |hile (IN|_PROXIMI|
|00002940| 54 59 0d 09 09 09 09 26 | 26 20 54 69 63 6b 43 6f |TY.....&|& TickCo|
|00002950| 75 6e 74 28 29 20 2d 20 | 74 68 65 53 74 72 6f 6b |unt() - |theStrok|
|00002960| 65 2d 3e 65 6e 64 5f 74 | 69 6d 65 20 3c 20 4d 55 |e->end_t|ime < MU|
|00002970| 4c 54 49 5f 54 49 4d 45 | 5f 4f 55 54 0d 09 09 09 |LTI_TIME|_OUT....|
|00002980| 09 26 26 20 53 74 72 6f | 6b 65 4d 61 79 43 6f 6e |.&& Stro|keMayCon|
|00002990| 74 69 6e 75 65 28 29 29 | 0d 09 09 7b 0d 09 09 45 |tinue())|...{...E|
|000029a0| 76 65 6e 74 52 65 63 6f | 72 64 20 65 76 65 6e 74 |ventReco|rd event|
|000029b0| 3b 0d 09 09 69 66 20 28 | 47 65 74 4f 53 45 76 65 |;...if (|GetOSEve|
|000029c0| 6e 74 28 6d 44 6f 77 6e | 4d 61 73 6b 2c 26 65 76 |nt(mDown|Mask,&ev|
|000029d0| 65 6e 74 29 29 20 7b 0d | 09 09 09 50 6f 69 6e 74 |ent)) {.|...Point|
|000029e0| 20 77 68 65 72 65 3b 0d | 09 09 09 69 66 20 28 57 | where;.|...if (W|
|000029f0| 61 63 6f 6d 29 20 7b 0d | 09 09 09 09 77 68 65 72 |acom) {.|....wher|
|00002a00| 65 2e 68 20 3d 20 54 52 | 65 63 6f 72 64 2d 3e 78 |e.h = TR|ecord->x|
|00002a10| 43 6f 6f 72 64 3b 0d 09 | 09 09 09 77 68 65 72 65 |Coord;..|...where|
|00002a20| 2e 76 20 3d 20 54 52 65 | 63 6f 72 64 2d 3e 79 43 |.v = TRe|cord->yC|
|00002a30| 6f 6f 72 64 3b 0d 09 09 | 09 09 7d 0d 09 09 09 65 |oord;...|..}....e|
|00002a40| 6c 73 65 20 7b 0d 09 09 | 09 09 77 68 65 72 65 20 |lse {...|..where |
|00002a50| 3d 20 65 76 65 6e 74 2e | 77 68 65 72 65 3b 0d 09 |= event.|where;..|
|00002a60| 09 09 09 47 6c 6f 62 61 | 6c 54 6f 4c 6f 63 61 6c |...Globa|lToLocal|
|00002a70| 28 26 77 68 65 72 65 29 | 3b 0d 09 09 09 09 7d 0d |(&where)|;.....}.|
|00002a80| 09 09 09 0d 09 09 20 09 | 74 68 65 53 74 72 6f 6b |...... .|theStrok|
|00002a90| 65 20 3d 20 63 61 6c 6c | 6f 63 28 31 2c 73 69 7a |e = call|oc(1,siz|
|00002aa0| 65 6f 66 28 53 74 72 6f | 6b 65 44 61 74 61 29 29 |eof(Stro|keData))|
|00002ab0| 3b 0d 09 09 09 69 66 20 | 28 74 68 65 53 74 72 6f |;....if |(theStro|
|00002ac0| 6b 65 20 3d 3d 20 4e 49 | 4c 29 20 7b 53 79 73 42 |ke == NI|L) {SysB|
|00002ad0| 65 65 70 28 31 29 3b 20 | 44 65 62 75 67 67 65 72 |eep(1); |Debugger|
|00002ae0| 28 29 3b 20 45 78 69 74 | 54 6f 53 68 65 6c 6c 28 |(); Exit|ToShell(|
|00002af0| 29 3b 7d 0d 09 09 20 09 | 74 68 65 53 74 72 6f 6b |);}... .|theStrok|
|00002b00| 65 2d 3e 73 74 61 72 74 | 5f 74 69 6d 65 20 3d 20 |e->start|_time = |
|00002b10| 65 76 65 6e 74 2e 77 68 | 65 6e 3b 0d 09 09 09 43 |event.wh|en;....C|
|00002b20| 6f 6c 6c 65 63 74 53 74 | 72 6f 6b 65 28 77 68 65 |ollectSt|roke(whe|
|00002b30| 72 65 2c 74 68 65 53 74 | 72 6f 6b 65 29 3b 0d 09 |re,theSt|roke);..|
|00002b40| 09 09 46 6c 75 73 68 45 | 76 65 6e 74 73 28 65 76 |..FlushE|vents(ev|
|00002b50| 65 72 79 45 76 65 6e 74 | 2c 30 29 3b 0d 09 09 09 |eryEvent|,0);....|
|00002b60| 41 70 70 65 6e 64 28 26 | 53 74 72 6f 6b 65 73 2c |Append(&|Strokes,|
|00002b70| 28 6c 6f 6e 67 29 74 68 | 65 53 74 72 6f 6b 65 29 |(long)th|eStroke)|
|00002b80| 3b 0d 09 09 09 52 65 63 | 6f 67 6e 69 7a 65 53 74 |;....Rec|ognizeSt|
|00002b90| 72 6f 6b 65 28 53 74 72 | 6f 6b 65 73 2d 3e 6e 75 |roke(Str|okes->nu|
|00002ba0| 6d 5f 69 74 65 6d 73 20 | 2d 20 31 29 3b 0d 09 09 |m_items |- 1);...|
|00002bb0| 09 7d 0d 09 09 7d 0d 0d | 09 63 6f 64 65 20 3d 20 |.}...}..|.code = |
|00002bc0| 52 65 63 6f 67 6e 69 7a | 65 28 29 3b 0d 09 43 6f |Recogniz|e();..Co|
|00002bd0| 6d 70 75 74 65 42 42 6f | 78 28 29 3b 0d 20 09 69 |mputeBBo|x();. .i|
|00002be0| 66 20 28 53 74 72 6f 6b | 65 73 29 0d 20 09 09 66 |f (Strok|es). ..f|
|00002bf0| 6f 72 20 28 69 20 3d 20 | 30 3b 20 69 20 3c 20 53 |or (i = |0; i < S|
|00002c00| 74 72 6f 6b 65 73 2d 3e | 6e 75 6d 5f 69 74 65 6d |trokes->|num_item|
|00002c10| 73 3b 20 69 2b 2b 29 20 | 7b 0d 20 09 09 09 53 74 |s; i++) |{. ...St|
|00002c20| 72 6f 6b 65 50 74 72 20 | 74 68 65 53 74 72 6f 6b |rokePtr |theStrok|
|00002c30| 65 20 3d 20 53 74 72 6f | 6b 65 73 2d 3e 69 74 65 |e = Stro|kes->ite|
|00002c40| 6d 73 5b 69 5d 3b 0d 20 | 09 09 09 50 65 6e 53 74 |ms[i];. |...PenSt|
|00002c50| 61 74 65 20 74 68 65 50 | 6e 53 74 61 74 65 3b 0d |ate theP|nState;.|
|00002c60| 20 09 09 09 47 65 74 50 | 65 6e 53 74 61 74 65 28 | ...GetP|enState(|
|00002c70| 26 74 68 65 50 6e 53 74 | 61 74 65 29 3b 0d 20 09 |&thePnSt|ate);. .|
|00002c80| 09 09 50 65 6e 4d 6f 64 | 65 28 70 61 74 58 6f 72 |..PenMod|e(patXor|
|00002c90| 29 3b 0d 20 09 09 09 66 | 6f 72 20 28 6a 20 3d 20 |);. ...f|or (j = |
|00002ca0| 30 3b 20 6a 20 3c 20 74 | 68 65 53 74 72 6f 6b 65 |0; j < t|heStroke|
|00002cb0| 2d 3e 49 6e 6b 5f 4e 75 | 6d 3b 20 6a 2b 2b 29 20 |->Ink_Nu|m; j++) |
|00002cc0| 7b 0d 20 09 09 09 09 50 | 6f 69 6e 74 20 64 72 61 |{. ....P|oint dra|
|00002cd0| 77 6d 65 2c 70 20 3d 20 | 74 68 65 53 74 72 6f 6b |wme,p = |theStrok|
|00002ce0| 65 2d 3e 49 6e 6b 5b 6a | 5d 3b 0d 09 09 09 09 69 |e->Ink[j|];.....i|
|00002cf0| 66 20 28 57 61 63 6f 6d | 29 20 7b 0d 09 09 09 09 |f (Wacom|) {.....|
|00002d00| 09 64 72 61 77 6d 65 2e | 68 20 3d 20 54 41 42 5f |.drawme.|h = TAB_|
|00002d10| 54 4f 5f 53 43 52 45 45 | 4e 5f 58 28 70 2e 68 29 |TO_SCREE|N_X(p.h)|
|00002d20| 3b 0d 09 09 09 09 09 64 | 72 61 77 6d 65 2e 76 20 |;......d|rawme.v |
|00002d30| 3d 20 54 41 42 5f 54 4f | 5f 53 43 52 45 45 4e 5f |= TAB_TO|_SCREEN_|
|00002d40| 59 28 70 2e 76 29 3b 0d | 09 09 09 09 09 47 6c 6f |Y(p.v);.|.....Glo|
|00002d50| 62 61 6c 54 6f 4c 6f 63 | 61 6c 28 26 64 72 61 77 |balToLoc|al(&draw|
|00002d60| 6d 65 29 3b 0d 09 09 09 | 09 09 7d 0d 09 09 09 09 |me);....|..}.....|
|00002d70| 65 6c 73 65 0d 09 09 09 | 09 09 64 72 61 77 6d 65 |else....|..drawme|
|00002d80| 20 3d 20 70 3b 0d 20 09 | 09 09 09 4d 6f 76 65 54 | = p;. .|...MoveT|
|00002d90| 6f 28 64 72 61 77 6d 65 | 2e 68 2c 64 72 61 77 6d |o(drawme|.h,drawm|
|00002da0| 65 2e 76 29 3b 0d 20 09 | 09 09 09 4c 69 6e 65 54 |e.v);. .|...LineT|
|00002db0| 6f 28 64 72 61 77 6d 65 | 2e 68 2c 64 72 61 77 6d |o(drawme|.h,drawm|
|00002dc0| 65 2e 76 29 3b 0d 20 09 | 09 09 09 7d 0d 20 09 09 |e.v);. .|...}. ..|
|00002dd0| 09 53 65 74 50 65 6e 53 | 74 61 74 65 28 26 74 68 |.SetPenS|tate(&th|
|00002de0| 65 50 6e 53 74 61 74 65 | 29 3b 0d 20 09 09 09 7d |ePnState|);. ...}|
|00002df0| 0d 09 46 72 65 65 53 74 | 72 6f 6b 65 73 28 29 3b |..FreeSt|rokes();|
|00002e00| 0d 09 72 65 74 75 72 6e | 20 63 6f 64 65 3b 0d 09 |..return| code;..|
|00002e10| 7d 0d 0d 73 68 6f 72 74 | 09 09 56 6f 74 65 57 65 |}..short|..VoteWe|
|00002e20| 69 67 68 74 5b 5d 09 09 | 09 3d 20 7b 33 2c 33 2c |ight[]..|.= {3,3,|
|00002e30| 33 2c 33 2c 33 2c 33 2c | 33 2c 33 2c 33 7d 3b 0d |3,3,3,3,|3,3,3};.|
|00002e40| 63 68 61 72 09 09 42 69 | 74 73 5b 5d 09 09 09 09 |char..Bi|ts[]....|
|00002e50| 09 3d 20 7b 32 2c 32 2c | 32 2c 32 2c 33 2c 32 2c |.= {2,2,|2,2,3,2,|
|00002e60| 32 2c 32 2c 32 7d 3b 0d | 56 6f 69 64 46 75 6e 63 |2,2,2};.|VoidFunc|
|00002e70| 09 48 61 73 68 46 75 6e | 63 74 69 6f 6e 73 5b 5d |.HashFun|ctions[]|
|00002e80| 09 09 3d 20 7b 46 78 6e | 31 2c 46 78 6e 32 2c 46 |..= {Fxn|1,Fxn2,F|
|00002e90| 78 6e 61 2c 46 78 6e 62 | 2c 46 78 6e 63 2c 46 78 |xna,Fxnb|,Fxnc,Fx|
|00002ea0| 6e 64 2c 46 78 6e 34 2c | 46 78 6e 35 2c 46 78 6e |nd,Fxn4,|Fxn5,Fxn|
|00002eb0| 55 7d 3b 0d 63 68 61 72 | 09 09 2a 4e 61 6d 65 73 |U};.char|..*Names|
|00002ec0| 5b 4e 55 4d 5f 46 45 41 | 54 55 52 45 53 5d 09 3d |[NUM_FEA|TURES].=|
|00002ed0| 20 7b 22 57 4e 45 53 22 | 2c 22 41 42 43 44 22 7d | {"WNES"|,"ABCD"}|
|00002ee0| 3b 0d 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |;.......|........|
|00002ef0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002f00| 00 00 01 00 00 00 01 16 | 00 00 00 16 00 00 00 46 |........|.......F|
|00002f10| 7d 00 02 4a 65 46 52 45 | 46 00 01 00 01 29 b7 00 |}..JeFRE|F....)..|
|00002f20| 02 55 10 00 00 00 06 77 | 23 11 99 5f 32 00 00 01 |.U.....w|#.._2...|
|00002f30| 0a 41 6e 61 6c 79 7a 65 | 72 2e 63 79 02 00 00 00 |.Analyze|r.cy....|
|00002f40| 54 45 58 54 4b 41 48 4c | 01 00 00 00 00 00 00 00 |TEXTKAHL|........|
|00002f50| 00 00 54 45 58 54 4b 41 | 48 4c 01 00 00 00 00 00 |..TEXTKA|HL......|
|00002f60| 00 00 31 09 00 00 00 00 | 00 00 00 00 00 00 00 00 |..1.....|........|
|00002f70| 00 00 a4 fd 02 cf 00 00 | 2e 62 00 00 01 5c 87 0c |........|.b...\..|
|00002f80| 00 01 80 0c 00 00 c0 18 | 00 00 60 30 00 00 3f e0 |........|..`0..?.|
|00002f90| 00 00 1f c0 00 00 07 00 | 00 00 07 00 00 00 07 00 |........|........|
|00002fa0| 00 00 07 00 00 00 1f c0 | 00 00 7f f0 00 01 ff fc |........|........|
|00002fb0| 00 00 3f e0 00 00 7f f0 | 00 00 ff f8 00 00 ff f8 |..?.....|........|
|00002fc0| 00 00 ff f8 00 00 ff f8 | 00 01 ff fc 00 03 ff fe |........|........|
|00002fd0| 00 07 ff ff 00 07 ff ff | 00 07 ff ff 00 07 ff ff |........|........|
|00002fe0| 00 07 ff ff 00 07 ff ff | 00 07 ff ff 00 07 ff ff |........|........|
|00002ff0| 00 07 ff ff 00 07 ff ff | 00 07 ff ff 00 07 ff ff |........|........|
|00003000| 00 00 00 04 00 06 00 03 | 00 00 00 0a 00 09 06 4d |........|.......M|
|00003010| 6f 6e 61 63 6f 00 00 00 | 01 00 00 00 01 16 00 00 |onaco...|........|
|00003020| 00 16 00 00 00 46 00 25 | a0 a8 03 ae 00 00 00 1c |.....F.%|........|
|00003030| 00 46 00 01 45 54 41 42 | 00 00 00 12 45 46 4e 54 |.F..ETAB|....EFNT|
|00003040| 00 00 00 1e 03 ec ff ff | 00 00 00 00 00 25 a0 0c |........|.....%..|
|00003050| 03 eb ff ff 00 00 00 08 | 00 25 9f d4 00 00 00 00 |........|.%......|
|00003060| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00003070| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
+--------+-------------------------+-------------------------+--------+--------+